/*
 Theme Name:   AtuCasa Habana
 Theme URI:    https://atucasa.app
 Description:  Tema personalizado para AtuCasa Habana — Marketplace geolocalizado. Child theme de Storefront.
 Author:       AtuCasa
 Template:     storefront
 Version:      1.0.0
 Text Domain:  atucasa-theme
*/

/* =========================================================================
   VARIABLES — Paleta inspirada en Supermarket23
   ====================================================================== */
:root {
    --atc-brand: #e63946;
    --atc-brand-dark: #c1121f;
    --atc-brand-light: #fce4e6;
    --atc-secondary: #1d3557;
    --atc-accent: #f4a261;
    --atc-green: #2a9d8f;
    --atc-bg: #f8f9fa;
    --atc-white: #ffffff;
    --atc-text: #2b2d42;
    --atc-text-light: #6c757d;
    --atc-border: #e9ecef;
    --atc-radius: 10px;
    --atc-radius-lg: 16px;
    --atc-shadow: 0 2px 8px rgba(0,0,0,.06);
    --atc-shadow-hover: 0 8px 24px rgba(0,0,0,.1);
}

/* =========================================================================
   GLOBAL / BODY
   ====================================================================== */
body {
    background: var(--atc-bg);
    color: var(--atc-text);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
}

/* =========================================================================
   HEADER — Estilo marketplace
   ====================================================================== */
.site-header {
    background: var(--atc-secondary) !important;
    border-bottom: 3px solid var(--atc-brand);
    box-shadow: 0 2px 10px rgba(0,0,0,.15);
}

.site-header .site-title a,
.site-header .site-description {
    color: var(--atc-white) !important;
}

.site-header .site-title a {
    font-weight: 800;
    font-size: 26px;
    letter-spacing: -0.5px;
}

/* Logo */
.custom-logo {
    max-height: 50px;
    width: auto;
}

/* Navigation */
.main-navigation ul li a {
    color: rgba(255,255,255,.9) !important;
    font-weight: 500;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 12px 16px;
    transition: color .2s, background .2s;
}

.main-navigation ul li a:hover,
.main-navigation ul li.current-menu-item a {
    color: var(--atc-white) !important;
    background: rgba(255,255,255,.1);
    border-radius: 6px;
}

/* Cart icon */
.site-header-cart .cart-contents {
    color: var(--atc-white) !important;
}

.site-header-cart .cart-contents .count {
    background: var(--atc-brand) !important;
    color: var(--atc-white);
    font-weight: 700;
    border-radius: 50%;
    min-width: 22px;
    height: 22px;
    line-height: 22px;
    text-align: center;
    font-size: 11px;
}

/* Search in header */
.site-search .widget_product_search input[type="search"] {
    border-radius: 25px;
    border: none;
    padding: 10px 20px;
    font-size: 14px;
    background: rgba(255,255,255,.15);
    color: var(--atc-white);
}

.site-search .widget_product_search input[type="search"]::placeholder {
    color: rgba(255,255,255,.6);
}

.site-search .widget_product_search input[type="search"]:focus {
    background: var(--atc-white);
    color: var(--atc-text);
    box-shadow: 0 0 0 3px rgba(230,57,70,.3);
}

/* =========================================================================
   BARRA DE UBICACIÓN — AtuCasa (sobreescribe plugin)
   ====================================================================== */
.atucasa-location-bar {
    background: var(--atc-brand) !important;
    color: var(--atc-white);
    font-weight: 600;
    font-size: 14px;
    padding: 10px 0;
    text-align: center;
    cursor: pointer;
    transition: background .2s;
}

.atucasa-location-bar:hover {
    background: var(--atc-brand-dark) !important;
}

/* =========================================================================
   CATEGORÍAS — Grid visual tipo Supermarket23
   ====================================================================== */
.storefront-product-categories {
    padding: 30px 0;
}

.storefront-product-categories ul.products li.product-category {
    background: var(--atc-white);
    border-radius: var(--atc-radius-lg);
    overflow: hidden;
    box-shadow: var(--atc-shadow);
    transition: transform .25s ease, box-shadow .25s ease;
    border: 1px solid var(--atc-border);
}

.storefront-product-categories ul.products li.product-category:hover {
    transform: translateY(-4px);
    box-shadow: var(--atc-shadow-hover);
}

.storefront-product-categories ul.products li.product-category a img {
    border-radius: 0;
    aspect-ratio: 4/3;
    object-fit: cover;
}

.storefront-product-categories ul.products li.product-category a h2,
.storefront-product-categories ul.products li.product-category a .woocommerce-loop-category__title {
    font-size: 15px;
    font-weight: 700;
    color: var(--atc-text);
    padding: 12px 14px;
    margin: 0;
    text-align: center;
    background: var(--atc-white);
}

.storefront-product-categories ul.products li.product-category a .count {
    background: var(--atc-brand-light);
    color: var(--atc-brand);
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
}

/* =========================================================================
   PRODUCTOS — Grid tipo marketplace
   ====================================================================== */
ul.products {
    margin: 0 !important;
}

ul.products li.product {
    background: var(--atc-white);
    border-radius: var(--atc-radius-lg);
    overflow: hidden;
    box-shadow: var(--atc-shadow);
    transition: transform .25s ease, box-shadow .25s ease;
    border: 1px solid var(--atc-border);
    padding: 0 !important;
    margin-bottom: 20px !important;
}

ul.products li.product:hover {
    transform: translateY(-3px);
    box-shadow: var(--atc-shadow-hover);
}

/* Product image */
ul.products li.product a img,
ul.products li.product img.attachment-woocommerce_thumbnail {
    border-radius: 0;
    margin: 0 !important;
    aspect-ratio: 1;
    object-fit: cover;
    width: 100%;
}

/* Product info */
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h2 {
    font-size: 14px !important;
    font-weight: 600;
    color: var(--atc-text);
    padding: 12px 14px 4px !important;
    margin: 0;
    line-height: 1.3;
    min-height: 40px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Price */
ul.products li.product .price {
    padding: 0 14px 6px;
    font-size: 18px !important;
    font-weight: 800;
    color: var(--atc-brand) !important;
}

ul.products li.product .price del {
    color: var(--atc-text-light);
    font-size: 13px;
    font-weight: 400;
}

ul.products li.product .price ins {
    text-decoration: none;
    color: var(--atc-brand);
}

/* Sale badge */
ul.products li.product .onsale,
.single-product .onsale {
    background: var(--atc-brand) !important;
    color: var(--atc-white);
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    padding: 4px 10px;
    line-height: 1.5;
    top: 10px;
    left: 10px;
    right: auto;
    min-height: auto;
    min-width: auto;
}

/* Add to cart button */
ul.products li.product .button,
ul.products li.product a.add_to_cart_button {
    background: var(--atc-brand) !important;
    color: var(--atc-white) !important;
    border: none !important;
    border-radius: 0 0 var(--atc-radius-lg) var(--atc-radius-lg);
    padding: 12px 14px !important;
    font-weight: 700;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    width: 100%;
    text-align: center;
    transition: background .2s;
    margin: 0 !important;
    display: block;
}

ul.products li.product .button:hover,
ul.products li.product a.add_to_cart_button:hover {
    background: var(--atc-brand-dark) !important;
}

/* Star rating */
ul.products li.product .star-rating {
    padding: 0 14px;
    margin: 4px 0;
}

/* =========================================================================
   PRODUCTO SINGLE — Detalle
   ====================================================================== */
.single-product div.product {
    background: var(--atc-white);
    border-radius: var(--atc-radius-lg);
    padding: 24px;
    box-shadow: var(--atc-shadow);
}

.single-product div.product .summary .price {
    font-size: 28px !important;
    color: var(--atc-brand) !important;
    font-weight: 800;
}

.single-product div.product .single_add_to_cart_button {
    background: var(--atc-brand) !important;
    border-color: var(--atc-brand) !important;
    border-radius: var(--atc-radius);
    padding: 14px 36px !important;
    font-size: 16px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    transition: background .2s;
}

.single-product div.product .single_add_to_cart_button:hover {
    background: var(--atc-brand-dark) !important;
}

.single-product div.product .quantity .qty {
    border-radius: var(--atc-radius);
    border: 2px solid var(--atc-border);
    padding: 10px;
    font-size: 16px;
    width: 70px;
}

/* =========================================================================
   SIDEBAR / WIDGETS
   ====================================================================== */
.widget {
    background: var(--atc-white);
    border-radius: var(--atc-radius);
    padding: 20px;
    box-shadow: var(--atc-shadow);
    margin-bottom: 20px;
    border: 1px solid var(--atc-border);
}

.widget h2.widget-title,
.widget .widget-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--atc-secondary);
    border-bottom: 2px solid var(--atc-brand);
    padding-bottom: 10px;
    margin-bottom: 14px;
}

/* Price filter */
.widget_price_filter .price_slider_wrapper .ui-widget-content {
    background: var(--atc-border);
}

.widget_price_filter .ui-slider .ui-slider-range {
    background: var(--atc-brand);
}

.widget_price_filter .ui-slider .ui-slider-handle {
    background: var(--atc-brand);
    border-color: var(--atc-brand);
}

/* =========================================================================
   CARRITO
   ====================================================================== */
.woocommerce-cart table.cart {
    background: var(--atc-white);
    border-radius: var(--atc-radius);
    overflow: hidden;
    box-shadow: var(--atc-shadow);
}

.woocommerce-cart .cart_totals {
    background: var(--atc-white);
    border-radius: var(--atc-radius);
    padding: 20px;
    box-shadow: var(--atc-shadow);
}

.woocommerce a.button.checkout-button,
.woocommerce .checkout-button {
    background: var(--atc-brand) !important;
    border-radius: var(--atc-radius) !important;
    font-weight: 700;
    font-size: 16px;
    padding: 14px !important;
}

.woocommerce a.button.checkout-button:hover {
    background: var(--atc-brand-dark) !important;
}

/* =========================================================================
   CHECKOUT
   ====================================================================== */
.woocommerce-checkout #payment {
    background: var(--atc-white);
    border-radius: var(--atc-radius);
    box-shadow: var(--atc-shadow);
}

.woocommerce-checkout #place_order {
    background: var(--atc-brand) !important;
    border-radius: var(--atc-radius);
    font-size: 18px;
    font-weight: 700;
    padding: 16px 32px;
    text-transform: uppercase;
}

.woocommerce-checkout #place_order:hover {
    background: var(--atc-brand-dark) !important;
}

/* Checkout location reminder */
.atucasa-checkout-location {
    background: var(--atc-green);
    color: var(--atc-white);
    padding: 12px 20px;
    border-radius: var(--atc-radius);
    margin-bottom: 20px;
    font-weight: 500;
}

.atucasa-checkout-location a {
    color: var(--atc-white);
    text-decoration: underline;
}

.atucasa-checkout-warning {
    background: var(--atc-brand-light);
    border-left: 4px solid var(--atc-brand);
    padding: 14px 20px;
    border-radius: var(--atc-radius);
}

/* =========================================================================
   FOOTER
   ====================================================================== */
.site-footer {
    background: var(--atc-secondary) !important;
    color: rgba(255,255,255,.8);
}

.site-footer a {
    color: var(--atc-white);
}

.site-footer .widget-title {
    color: var(--atc-white);
    border-bottom-color: var(--atc-brand);
}

.site-info {
    background: rgba(0,0,0,.2) !important;
    color: rgba(255,255,255,.6);
    font-size: 13px;
}

/* =========================================================================
   BOTONES GENERALES
   ====================================================================== */
.storefront-button,
button,
input[type="submit"],
.button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
    border-radius: var(--atc-radius) !important;
    font-weight: 600;
    transition: all .2s ease;
}

.woocommerce a.button.alt,
.woocommerce button.button.alt {
    background: var(--atc-brand) !important;
    border-color: var(--atc-brand) !important;
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
    background: var(--atc-brand-dark) !important;
}

/* =========================================================================
   BREADCRUMBS
   ====================================================================== */
.woocommerce-breadcrumb {
    background: var(--atc-white);
    padding: 12px 20px;
    border-radius: var(--atc-radius);
    margin-bottom: 20px;
    font-size: 13px;
    color: var(--atc-text-light);
    box-shadow: var(--atc-shadow);
}

.woocommerce-breadcrumb a {
    color: var(--atc-brand);
}

/* =========================================================================
   PAGINATION
   ====================================================================== */
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span.current {
    border-radius: var(--atc-radius);
    font-weight: 600;
}

.woocommerce nav.woocommerce-pagination ul li span.current {
    background: var(--atc-brand) !important;
    border-color: var(--atc-brand) !important;
}

/* =========================================================================
   MODAL DE UBICACIÓN — Sobreescribir plugin
   ====================================================================== */
.atucasa-modal-overlay {
    background: rgba(29,53,87,.85) !important;
}

.atucasa-modal {
    border-radius: var(--atc-radius-lg) !important;
    box-shadow: 0 20px 60px rgba(0,0,0,.3) !important;
}

.atucasa-modal .atucasa-btn.primary {
    background: var(--atc-brand) !important;
    border-color: var(--atc-brand) !important;
}

/* =========================================================================
   RESPONSIVE
   ====================================================================== */

/* Mobile: 2 columnas de productos */
@media (max-width: 767px) {
    ul.products li.product {
        width: 48% !important;
        margin-right: 4% !important;
    }
    ul.products li.product:nth-child(2n) {
        margin-right: 0 !important;
    }

    ul.products li.product .woocommerce-loop-product__title,
    ul.products li.product h2 {
        font-size: 13px !important;
        padding: 8px 10px 2px !important;
    }

    ul.products li.product .price {
        font-size: 15px !important;
        padding: 0 10px 4px;
    }

    ul.products li.product .button {
        font-size: 11px;
        padding: 10px !important;
    }

    .site-header .site-title a {
        font-size: 20px;
    }
}

/* Tablet: 3 columnas */
@media (min-width: 768px) and (max-width: 1023px) {
    ul.products li.product {
        width: 31.33% !important;
        margin-right: 3% !important;
    }
    ul.products li.product:nth-child(3n) {
        margin-right: 0 !important;
    }
}

/* Desktop: 4 columnas */
@media (min-width: 1024px) {
    ul.products li.product {
        width: 23.5% !important;
        margin-right: 2% !important;
    }
    ul.products li.product:nth-child(4n) {
        margin-right: 0 !important;
    }
}

/* =========================================================================
   UTILIDADES
   ====================================================================== */
.atucasa-hide { display: none !important; }

/* Smooth scrolling */
html { scroll-behavior: smooth; }

/* Better images */
img { max-width: 100%; height: auto; }

/* Remove Storefront credit */
.site-info .site-credit { display: none; }