/* ============================================
   WINUCAR — Competition Page
   Police recommandée : Inter (Google Fonts)
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

/* ── Variables ── */
:root {
    --wuc-bg:          #0D0D0D;
    --wuc-surface:     #161616;
    --wuc-surface-2:   #1F1F1F;
    --wuc-accent:      #E8FF00;
    --wuc-accent-dark: #C8DF00;
    --wuc-white:       #FFFFFF;
    --wuc-muted:       #6B6B6B;
    --wuc-border:      rgba(255,255,255,0.08);
    --wuc-radius:      12px;
    --wuc-font:        'Inter', system-ui, -apple-system, sans-serif;
}

/* ── Reset global pour la page ── */
.wuc-page,
.wuc-page * {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

.wuc-page {
    background: var(--wuc-bg);
    color: var(--wuc-white);
    font-family: var(--wuc-font);
    -webkit-font-smoothing: antialiased;
}

/* Masquer les éléments Astra non voulus */
.single-product .ast-breadcrumbs-wrapper,
.single-product .woocommerce-notices-wrapper,
.single-product .ast-container > .entry-header { display: none !important; }

.single-product .site-main { background: var(--wuc-bg) !important; }
.single-product .entry-content { padding: 0 !important; margin: 0 !important; }


/* ════════════════════════════════════════════
   LAYOUT : SPLIT ÉCRAN
════════════════════════════════════════════ */

.wuc-split {
    display: grid;
    grid-template-columns: 58% 42%;
    min-height: 100vh;
}

/* ── Gauche : image ── */
.wuc-visual {
    position: sticky;
    top: 0;
    height: 100vh;
    overflow: hidden;
}

.wuc-car-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.wuc-placeholder-img {
    background: var(--wuc-surface);
}

.wuc-visual-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.75) 0%, transparent 55%);
    display: flex;
    align-items: flex-end;
    padding: 40px;
    pointer-events: none;
}

.wuc-value-badge {
    background: rgba(255,255,255,.07);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 10px;
    padding: 14px 22px;
    pointer-events: auto;
}

.wuc-value-label {
    display: block;
    font-size: 11px;
    color: rgba(255,255,255,.6);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    margin-bottom: 4px;
}

.wuc-value-amount {
    display: block;
    font-size: 26px;
    font-weight: 800;
    color: var(--wuc-accent);
    letter-spacing: -0.5px;
}


/* ── Droite : panel ── */
.wuc-panel {
    background: var(--wuc-bg);
    height: 100vh;
    overflow-y: auto;
    padding: 56px 48px 60px;
    scroll-behavior: smooth;
}

/* Scrollbar discrète */
.wuc-panel::-webkit-scrollbar { width: 4px; }
.wuc-panel::-webkit-scrollbar-track { background: transparent; }
.wuc-panel::-webkit-scrollbar-thumb { background: var(--wuc-surface-2); border-radius: 2px; }


/* ════════════════════════════════════════════
   BADGE STATUT
════════════════════════════════════════════ */

.wuc-status-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(232,255,0,.08);
    border: 1px solid rgba(232,255,0,.25);
    color: var(--wuc-accent);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 2.5px;
    padding: 6px 14px;
    border-radius: 4px;
    margin-bottom: 22px;
}

.wuc-dot {
    width: 6px;
    height: 6px;
    background: var(--wuc-accent);
    border-radius: 50%;
    animation: wuc-pulse 1.6s ease infinite;
}

@keyframes wuc-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: .45; transform: scale(.75); }
}


/* ════════════════════════════════════════════
   TITRE & EXCERPT
════════════════════════════════════════════ */

.wuc-title.product_title,
.wuc-title {
    font-size: 38px !important;
    font-weight: 900 !important;
    line-height: 1.08 !important;
    letter-spacing: -1.5px !important;
    color: var(--wuc-white) !important;
    margin-bottom: 14px !important;
}

.wuc-excerpt {
    font-size: 15px;
    color: var(--wuc-muted);
    line-height: 1.65;
    margin-bottom: 28px;
}


/* ════════════════════════════════════════════
   COMPTE À REBOURS
════════════════════════════════════════════ */

.wuc-countdown {
    display: flex;
    align-items: center;
    gap: 6px;
    background: var(--wuc-surface);
    border: 1px solid var(--wuc-border);
    border-radius: var(--wuc-radius);
    padding: 20px 16px;
    margin-bottom: 28px;
}

.wuc-cd-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
}

.wuc-cd-num {
    font-size: 30px;
    font-weight: 800;
    color: var(--wuc-white);
    font-variant-numeric: tabular-nums;
    letter-spacing: -1px;
    line-height: 1;
}

.wuc-cd-lbl {
    font-size: 9px;
    color: var(--wuc-muted);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    margin-top: 5px;
}

.wuc-cd-sep {
    font-size: 22px;
    font-weight: 700;
    color: var(--wuc-accent);
    opacity: .6;
    padding-bottom: 14px;
    user-select: none;
}


/* ════════════════════════════════════════════
   BARRE DE PROGRESSION
════════════════════════════════════════════ */

.wuc-progress-wrap { margin-bottom: 24px; }

.wuc-progress-track {
    height: 5px;
    background: var(--wuc-surface-2);
    border-radius: 3px;
    overflow: hidden;
    margin-bottom: 10px;
}

.wuc-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--wuc-accent) 0%, #BEFF00 100%);
    border-radius: 3px;
    transition: width .6s ease;
}

.wuc-progress-meta {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: var(--wuc-muted);
}

.wuc-divider {
    height: 1px;
    background: var(--wuc-border);
    margin: 22px 0;
}


/* ════════════════════════════════════════════
   PRIX TICKET
════════════════════════════════════════════ */

.wuc-ticket-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.wuc-ticket-label {
    font-size: 13px;
    color: var(--wuc-muted);
}

.wuc-ticket-price,
.wuc-ticket-price .woocommerce-Price-amount {
    font-size: 26px !important;
    font-weight: 800 !important;
    color: var(--wuc-white) !important;
    letter-spacing: -0.5px;
}

.wuc-ticket-price .woocommerce-Price-currencySymbol {
    font-size: 16px;
    vertical-align: super;
}


/* ════════════════════════════════════════════
   WOOCOMMERCE : QUANTITÉ + BOUTON
════════════════════════════════════════════ */

.wuc-page form.cart {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin: 0 0 16px !important;
}

/* Conteneur quantité */
.wuc-page .quantity {
    display: flex;
    align-items: center;
    gap: 0;
    border: 1px solid var(--wuc-border);
    border-radius: 8px;
    overflow: hidden;
    width: 160px;
    background: var(--wuc-surface);
}

.wuc-page input.qty {
    width: 64px !important;
    height: 50px !important;
    background: transparent !important;
    border: none !important;
    color: var(--wuc-white) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    font-family: var(--wuc-font) !important;
    text-align: center !important;
    outline: none !important;
    -moz-appearance: textfield !important;
}

.wuc-page input.qty::-webkit-inner-spin-button,
.wuc-page input.qty::-webkit-outer-spin-button { -webkit-appearance: none; }

/* Boutons +/- (ajoutés par WooCommerce ou plugin quantity) */
.wuc-page .minus,
.wuc-page .plus {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 48px !important;
    height: 50px !important;
    background: var(--wuc-surface-2) !important;
    border: none !important;
    color: var(--wuc-white) !important;
    font-size: 20px !important;
    font-weight: 400 !important;
    cursor: pointer !important;
    transition: background .18s, color .18s !important;
    line-height: 1 !important;
}

.wuc-page .minus:hover,
.wuc-page .plus:hover {
    background: var(--wuc-accent) !important;
    color: var(--wuc-bg) !important;
}

/* Bouton ajouter au panier */
.wuc-page button.single_add_to_cart_button,
.wuc-page .single_add_to_cart_button {
    width: 100% !important;
    background: var(--wuc-accent) !important;
    color: var(--wuc-bg) !important;
    border: none !important;
    padding: 17px 24px !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    font-family: var(--wuc-font) !important;
    letter-spacing: .5px !important;
    text-transform: uppercase !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: background .18s, transform .15s !important;
    box-shadow: none !important;
}

.wuc-page button.single_add_to_cart_button:hover {
    background: var(--wuc-accent-dark) !important;
    transform: translateY(-1px) !important;
}

/* Ligne total dynamique */
.wuc-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: var(--wuc-surface);
    border: 1px solid var(--wuc-border);
    border-radius: 8px;
    font-size: 14px;
    color: var(--wuc-muted);
}

.wuc-total-amount {
    font-size: 20px;
    font-weight: 800;
    color: var(--wuc-white);
}


/* ════════════════════════════════════════════
   QUESTION DE CONNAISSANCE
════════════════════════════════════════════ */

.wuc-question {
    background: var(--wuc-surface);
    border: 1px solid var(--wuc-border);
    border-radius: var(--wuc-radius);
    padding: 22px 20px;
    margin-top: 20px;
    margin-bottom: 16px;
}

.wuc-question-header {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 10px;
    font-weight: 700;
    color: var(--wuc-accent);
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 14px;
}

.wuc-question-text {
    color: var(--wuc-white);
    font-size: 16px;
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: 16px;
}

.wuc-answers {
    display: flex;
    flex-direction: column;
    gap: 9px;
}

.wuc-answer {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: var(--wuc-surface-2);
    border: 1px solid var(--wuc-border);
    border-radius: 8px;
    cursor: pointer;
    transition: border-color .18s, background .18s;
    color: var(--wuc-white);
    font-size: 14px;
    font-weight: 500;
}

.wuc-answer:hover {
    border-color: rgba(232,255,0,.4);
    background: rgba(232,255,0,.04);
}

.wuc-answer input[type="radio"] { display: none; }

.wuc-answer:has(input:checked) {
    border-color: var(--wuc-accent);
    background: rgba(232,255,0,.07);
}

.wuc-answer-letter {
    width: 28px;
    height: 28px;
    background: rgba(255,255,255,.06);
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
    color: var(--wuc-muted);
    flex-shrink: 0;
    transition: background .18s, color .18s;
}

.wuc-answer:has(input:checked) .wuc-answer-letter {
    background: var(--wuc-accent);
    color: var(--wuc-bg);
}


/* ── Mention légale ── */
.wuc-legal {
    font-size: 12px;
    color: var(--wuc-muted);
    line-height: 1.55;
    margin-top: 6px;
}

.wuc-legal a {
    color: rgba(232,255,0,.7);
    text-decoration: none;
}

.wuc-legal a:hover { color: var(--wuc-accent); }


/* ════════════════════════════════════════════
   BAS DE PAGE : ONGLETS
════════════════════════════════════════════ */

.wuc-bottom {
    background: var(--wuc-bg);
    border-top: 1px solid var(--wuc-border);
    padding: 60px;
}

.wuc-tabs {
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--wuc-border);
    margin-bottom: 44px;
}

.wuc-tab {
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--wuc-muted);
    font-family: var(--wuc-font);
    font-size: 14px;
    font-weight: 600;
    padding: 14px 26px;
    cursor: pointer;
    margin-bottom: -1px;
    transition: color .18s, border-color .18s;
    letter-spacing: .2px;
}

.wuc-tab:hover { color: var(--wuc-white); }

.wuc-tab.is-active {
    color: var(--wuc-accent);
    border-bottom-color: var(--wuc-accent);
}

.wuc-pane { display: none; }
.wuc-pane.is-active { display: block; }

.wuc-pane-inner {
    color: var(--wuc-muted);
    font-size: 15px;
    line-height: 1.7;
    max-width: 720px;
}

.wuc-pane-inner a { color: var(--wuc-accent); }

/* ── Steps "Comment ça marche" ── */
.wuc-steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.wuc-step {
    background: var(--wuc-surface);
    border: 1px solid var(--wuc-border);
    border-radius: var(--wuc-radius);
    padding: 28px 22px;
}

.wuc-step-n {
    display: block;
    font-size: 44px;
    font-weight: 900;
    color: rgba(232,255,0,.12);
    letter-spacing: -2px;
    line-height: 1;
    margin-bottom: 14px;
}

.wuc-step h4 {
    color: var(--wuc-white);
    font-size: 17px;
    font-weight: 700;
    margin-bottom: 8px;
}

.wuc-step p {
    color: var(--wuc-muted);
    font-size: 14px;
    line-height: 1.6;
}


/* ════════════════════════════════════════════
   RESPONSIVE MOBILE
════════════════════════════════════════════ */

@media (max-width: 900px) {
    .wuc-split {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .wuc-visual {
        position: relative;
        height: 52vw;
        min-height: 240px;
    }

    .wuc-panel {
        height: auto;
        padding: 32px 20px 48px;
    }

    .wuc-title { font-size: 28px !important; letter-spacing: -1px !important; }

    .wuc-cd-num { font-size: 24px; }

    .wuc-bottom {
        padding: 40px 20px;
    }

    .wuc-steps {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 480px) {
    .wuc-steps { grid-template-columns: 1fr; }
    .wuc-title { font-size: 24px !important; }
}
