/*
 Theme Name:   IPTV Space Child
 Theme URI:    https://iptvmaroc.space
 Description:  Thème enfant pour iptvmaroc.space — basé sur Astra
 Author:       DARILCOM
 Template:     astra
 Version:      1.0.0
 Text Domain:  iptv-space-child
*/

/* ============================================================
   VARIABLES GLOBALES
   ============================================================ */
:root {
    --iptv-red:    #d6111e;
    --iptv-dark:   #171422;
    --iptv-gold:   #ddc76d;
    --iptv-white:  #ffffff;
    --iptv-light:  #f9f9f9;
    --iptv-border: #e2e0ec;
    --iptv-font:   'Roboto', Arial, sans-serif;
}

/* ============================================================
   BASE
   ============================================================ */
body {
    font-family: var(--iptv-font) !important;
    color: #333;
    background: #fff;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--iptv-font) !important;
    font-weight: 700;
    color: var(--iptv-dark);
}

a {
    color: var(--iptv-red);
    transition: color .2s;
}
a:hover { color: #a50d18; text-decoration: none; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header,
.header-main,
header.site-header {
    background: var(--iptv-dark) !important;
    border-bottom: 3px solid var(--iptv-red);
}

.site-logo img {
    max-height: 55px;
    width: auto;
}

/* Navigation */
.main-navigation a,
.primary-menu a,
nav.navigation a {
    color: rgba(255,255,255,.85) !important;
    font-weight: 600;
    font-size: 14px;
    transition: color .2s;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.main-navigation a:hover,
.primary-menu a:hover {
    color: var(--iptv-gold) !important;
}

/* Bouton "Commander" dans le menu */
.menu-item-commander a,
.menu-item a[href*="checkout"] {
    background: var(--iptv-red) !important;
    color: #fff !important;
    padding: 8px 18px !important;
    border-radius: 50px !important;
    font-weight: 700 !important;
}
.menu-item-commander a:hover,
.menu-item a[href*="checkout"]:hover {
    background: #a50d18 !important;
    color: #fff !important;
}

/* ============================================================
   WOOCOMMERCE — BOUTONS
   ============================================================ */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce #payment #place_order {
    background: var(--iptv-red) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 50px !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    padding: 14px 32px !important;
    transition: all .25s !important;
    letter-spacing: .3px;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce #payment #place_order:hover {
    background: #a50d18 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(214,17,30,.35) !important;
}

.woocommerce a.button.alt,
.woocommerce button.button.alt {
    background: var(--iptv-dark) !important;
}
.woocommerce a.button.alt:hover { background: #2a2435 !important; }

/* ============================================================
   WOOCOMMERCE — CARDS PRODUITS
   ============================================================ */
.woocommerce ul.products li.product {
    border: 1px solid var(--iptv-border);
    border-radius: 12px;
    overflow: hidden;
    transition: box-shadow .25s, transform .25s;
    background: #fff;
}
.woocommerce ul.products li.product:hover {
    box-shadow: 0 8px 30px rgba(0,0,0,.1);
    transform: translateY(-3px);
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 15px !important;
    font-weight: 700;
    color: var(--iptv-dark);
}
.woocommerce ul.products li.product .price {
    color: var(--iptv-red) !important;
    font-weight: 700;
    font-size: 18px !important;
}

/* Badge "Gratuit" */
.woocommerce ul.products li.product .price bdi:empty::before,
.price:contains("0,00") {
    content: "GRATUIT";
    color: #22c55e;
}

/* ============================================================
   WOOCOMMERCE — PAGE PRODUIT
   ============================================================ */
.woocommerce div.product .product_title {
    font-size: 28px;
    font-weight: 900;
    color: var(--iptv-dark);
    margin-bottom: 10px;
}
.woocommerce div.product p.price {
    color: var(--iptv-red) !important;
    font-size: 32px !important;
    font-weight: 900 !important;
    margin-bottom: 20px;
}
.woocommerce div.product .woocommerce-product-details__short-description {
    font-size: 15px;
    line-height: 1.7;
    color: #555;
}

/* ============================================================
   WOOCOMMERCE — CHECKOUT
   ============================================================ */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
    border: 1.5px solid var(--iptv-border) !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    transition: border-color .2s;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus {
    border-color: var(--iptv-red) !important;
    outline: none;
    box-shadow: 0 0 0 3px rgba(214,17,30,.1);
}

#order_review_heading,
h3#order_review {
    font-size: 18px;
    font-weight: 700;
    color: var(--iptv-dark);
    border-bottom: 2px solid var(--iptv-red);
    padding-bottom: 10px;
    margin-bottom: 20px;
}

/* ============================================================
   WPFORMS
   ============================================================ */
.wpforms-container .wpforms-form .wpforms-field input,
.wpforms-container .wpforms-form .wpforms-field select,
.wpforms-container .wpforms-form .wpforms-field textarea {
    border: 1.5px solid var(--iptv-border) !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    font-family: var(--iptv-font) !important;
}
.wpforms-container .wpforms-form .wpforms-field input:focus,
.wpforms-container .wpforms-form .wpforms-field select:focus {
    border-color: var(--iptv-red) !important;
    box-shadow: 0 0 0 3px rgba(214,17,30,.1) !important;
}
.wpforms-submit-container button.wpforms-submit {
    background: var(--iptv-red) !important;
    border: none !important;
    border-radius: 50px !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    padding: 14px 36px !important;
    transition: all .25s !important;
}
.wpforms-submit-container button.wpforms-submit:hover {
    background: #a50d18 !important;
    transform: translateY(-1px);
}

/* ============================================================
   HERO / SECTIONS COMMUNES
   ============================================================ */
.iptv-hero {
    background: linear-gradient(135deg, var(--iptv-dark) 0%, #2d0a0e 100%);
    padding: 80px 20px;
    text-align: center;
}
.iptv-hero h1 {
    color: #fff;
    font-size: 2.5em;
    font-weight: 900;
    margin-bottom: 16px;
}
.iptv-hero p {
    color: var(--iptv-gold);
    font-size: 1.15em;
    margin-bottom: 32px;
}
.iptv-btn-primary {
    background: var(--iptv-red);
    color: #fff;
    padding: 16px 36px;
    border-radius: 50px;
    font-weight: 700;
    font-size: 1em;
    text-decoration: none;
    display: inline-block;
    transition: all .25s;
    margin: 6px;
}
.iptv-btn-primary:hover {
    background: #a50d18;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(214,17,30,.4);
}
.iptv-btn-outline {
    background: transparent;
    color: var(--iptv-gold);
    border: 2px solid var(--iptv-gold);
    padding: 16px 36px;
    border-radius: 50px;
    font-weight: 700;
    font-size: 1em;
    text-decoration: none;
    display: inline-block;
    transition: all .25s;
    margin: 6px;
}
.iptv-btn-outline:hover {
    background: var(--iptv-gold);
    color: var(--iptv-dark);
    transform: translateY(-2px);
}

/* ============================================================
   FAQ / ACCORDION
   ============================================================ */
details {
    margin-bottom: 14px;
    border: 1px solid var(--iptv-border);
    border-radius: 10px;
    overflow: hidden;
}
details summary {
    background: var(--iptv-light);
    padding: 18px 20px;
    font-weight: 700;
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: var(--iptv-dark);
}
details summary::after { content: '＋'; color: var(--iptv-red); font-size: 18px; }
details[open] summary::after { content: '－'; }
details[open] summary { color: var(--iptv-red); }
details > div {
    padding: 18px 20px;
    color: #555;
    line-height: 1.7;
    font-size: 14px;
}

/* ============================================================
   NOTICES / ALERTS
   ============================================================ */
.woocommerce-message,
.woocommerce-info {
    border-top-color: var(--iptv-red) !important;
}
.woocommerce-error { border-top-color: #dc2626 !important; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
    .iptv-hero h1 { font-size: 1.8em; }
    .iptv-hero { padding: 50px 16px; }

    .woocommerce ul.products li.product {
        border-radius: 8px;
    }
    .woocommerce div.product .product_title { font-size: 22px; }
    .woocommerce div.product p.price { font-size: 24px !important; }

    .woocommerce a.button,
    .woocommerce button.button,
    .woocommerce #payment #place_order {
        font-size: 14px !important;
        padding: 12px 24px !important;
    }
}
@media (max-width: 480px) {
    .iptv-hero h1 { font-size: 1.5em; }
}
