/**
 * Clean Product Card CSS
 * Version 10.0.0 - Poppins Edition
 */

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

/* ============================================
   CSS Variables
   ============================================ */
:root {
    --cpc-font: 'Poppins', sans-serif;
    --cpc-primary: #137E43;
    --cpc-dark: #1a1a1a;
    --cpc-gray-100: #f8f9fa;
    --cpc-gray-200: #e9ecef;
    --cpc-gray-300: #dee2e6;
    --cpc-gray-500: #6c757d;
    --cpc-gray-600: #495057;
    --cpc-success: #10b981;
    --cpc-danger: #ef4444;
    --cpc-radius: 16px;
    --cpc-radius-sm: 8px;
    --cpc-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    --cpc-shadow-hover: 0 12px 32px rgba(0, 0, 0, 0.1);
    --cpc-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ============================================
   Grid System
   ============================================ */
.woocommerce ul.products {
    display: grid !important;
    gap: 28px !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
    align-items: stretch !important;
}

.woocommerce ul.products.columns-1 { grid-template-columns: repeat(1, 1fr) !important; }
.woocommerce ul.products.columns-2 { grid-template-columns: repeat(2, 1fr) !important; }
.woocommerce ul.products.columns-3 { grid-template-columns: repeat(3, 1fr) !important; }
.woocommerce ul.products.columns-4 { grid-template-columns: repeat(4, 1fr) !important; }
.woocommerce ul.products.columns-5 { grid-template-columns: repeat(5, 1fr) !important; }
.woocommerce ul.products.columns-6 { grid-template-columns: repeat(6, 1fr) !important; }

.woocommerce ul.products li.product {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    display: flex !important;
    flex-direction: column !important;
}

/* ============================================
   Card Base
   ============================================ */
.cpc-card {
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    background: #fff !important;
    border-radius: var(--cpc-radius) !important;
    overflow: hidden !important;
    transition: var(--cpc-transition) !important;
    font-family: var(--cpc-font) !important;
    box-shadow: var(--cpc-shadow) !important;
    border: 1px solid var(--cpc-gray-200) !important;
}

.cpc-card:hover {
    transform: translateY(-6px) !important;
    box-shadow: var(--cpc-shadow-hover) !important;
    border-color: var(--cpc-gray-300) !important;
}

/* ============================================
   Image Container
   ============================================ */
.cpc-image-container {
    position: relative !important;
    padding-bottom: 75% !important;
    background: #fff;
    overflow: hidden !important;
}

.cpc-image-link {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
}

.cpc-images-wrapper {
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
}

.cpc-image {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    opacity: 0 !important;
    transition: opacity 0.4s ease !important;
    pointer-events: none !important;
}

.cpc-image.active {
    opacity: 1 !important;
}

/* ============================================
   Brand Badge
   ============================================ */
.cpc-brand-badge {
    position: absolute !important;
    top: 14px !important;
    left: 14px !important;
    z-index: 5 !important;
    background: #fff !important;
    border-radius: var(--cpc-radius-sm) !important;
    padding: 6px 10px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.cpc-brand-image {
    max-width: 60px !important;
    max-height: 28px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
}

/* ============================================
   Image Navigation (arrows hidden)
   ============================================ */
.cpc-nav-prev,
.cpc-nav-next {
    display: none !important;
}

.cpc-image-dots {
    position: absolute !important;
    bottom: 14px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    display: flex !important;
    gap: 8px !important;
    opacity: 0 !important;
    transition: var(--cpc-transition) !important;
    z-index: 4 !important;
}

.cpc-card:hover .cpc-image-dots {
    opacity: 1 !important;
}

.cpc-dot {
    width: 8px !important;
    height: 8px !important;
    background: rgba(255, 255, 255, 0.5) !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    transition: var(--cpc-transition) !important;
}

.cpc-dot.active {
    background: #fff !important;
    width: 24px !important;
    border-radius: 4px !important;
}

/* ============================================
   Tags
   ============================================ */
.cpc-tag {
    position: absolute !important;
    top: 14px !important;
    right: 14px !important;
    padding: 6px 12px !important;
    font-size: 10px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    border-radius: 6px !important;
    z-index: 10 !important;
    font-family: var(--cpc-font) !important;
}

.cpc-tag-exhibit {
    background: var(--cpc-dark) !important;
    color: #fff !important;
}

.cpc-tag-sale {
    background: var(--cpc-primary) !important;
    color: #fff !important;
    top: 48px !important; /* Under "På lager" tag */
}

/* ============================================
   Specs Bar (Trailers)
   ============================================ */
.cpc-specs-bar {
    display: flex !important;
    background: var(--cpc-gray-100) !important;
    border-top: 1px solid var(--cpc-gray-200) !important;
}

.cpc-spec-item {
    flex: 1 !important;
    padding: 10px 8px !important;
    text-align: center !important;
    border-right: 1px solid var(--cpc-gray-200) !important;
}

.cpc-spec-item:last-child {
    border-right: none !important;
}

.cpc-spec-label {
    font-size: 10px !important;
    font-weight: 500 !important;
    color: var(--cpc-gray-500) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    margin-bottom: 2px !important;
}

.cpc-spec-value {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--cpc-dark) !important;
}

/* ============================================
   Content Area
   ============================================ */
.cpc-content {
    flex-grow: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 18px !important;
}

.cpc-sku {
    font-size: 10px !important;
    font-weight: 500 !important;
    color: var(--cpc-gray-500) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 6px !important;
}

.cpc-title {
    margin: 0 0 10px 0 !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
}

.cpc-title a {
    color: var(--cpc-dark) !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
}

.cpc-title a:hover {
    color: var(--cpc-primary) !important;
}

/* ============================================
   Pricing
   ============================================ */
.cpc-price-wrapper {
    margin-bottom: 12px !important;
}

.cpc-price {
    font-family: var(--cpc-font) !important;
    display: flex !important;
    align-items: baseline !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
}

.cpc-price-incl {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--cpc-dark) !important;
    margin-bottom: 4px !important;
}

.cpc-price-excl {
    font-size: 12px !important;
    font-weight: 500 !important;
    color: var(--cpc-gray-500) !important;
    margin-bottom: 0 !important;
}

.cpc-price-label {
    font-size: 11px !important;
    font-weight: 400 !important;
    color: var(--cpc-gray-500) !important;
}

.cpc-price del {
    color: var(--cpc-gray-500) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
}

.cpc-price ins {
    text-decoration: none !important;
    color: var(--cpc-primary) !important;
}

/* ============================================
   Delivery Info
   ============================================ */
.cpc-delivery {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 10px 12px !important;
    background: var(--cpc-gray-100) !important;
    border-radius: var(--cpc-radius-sm) !important;
    margin-bottom: 14px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: var(--cpc-gray-600) !important;
}

.cpc-delivery i {
    color: var(--cpc-primary) !important;
    font-size: 14px !important;
}

/* ============================================
   Footer
   ============================================ */
.cpc-footer {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding-top: 14px !important;
    border-top: 1px solid var(--cpc-gray-200) !important;
    margin-top: auto !important;
}

.cpc-stock {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
}

.cpc-stock-dot {
    width: 8px !important;
    height: 8px !important;
    border-radius: 50% !important;
}

.cpc-stock.in-stock { 
    color: var(--cpc-success) !important; 
}
.cpc-stock.in-stock .cpc-stock-dot { 
    background: var(--cpc-success) !important; 
}
.cpc-stock.out-of-stock { 
    color: var(--cpc-danger) !important; 
}
.cpc-stock.out-of-stock .cpc-stock-dot { 
    background: var(--cpc-danger) !important; 
}

.cpc-add-to-cart,
.cpc-view-more,
.cpc-contact-btn {
    width: 42px !important;
    height: 42px !important;
    border: 2px solid var(--cpc-gray-200) !important;
    background: #fff !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--cpc-gray-500) !important;
    transition: var(--cpc-transition) !important;
    text-decoration: none !important;
}

.cpc-add-to-cart:hover {
    background: var(--cpc-primary) !important;
    border-color: var(--cpc-primary) !important;
    color: #fff !important;
    transform: rotate(90deg) !important;
}

.cpc-view-more:hover,
.cpc-contact-btn:hover {
    background: var(--cpc-dark) !important;
    border-color: var(--cpc-dark) !important;
    color: #fff !important;
}

.cpc-details-link {
    color: var(--cpc-dark) !important;
    text-decoration: none !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    transition: color 0.2s ease !important;
}

.cpc-details-link:hover {
    color: var(--cpc-primary) !important;
}

.cpc-details-link i {
    transition: transform 0.2s ease !important;
}

.cpc-details-link:hover i {
    transform: translateX(4px) !important;
}

/* ============================================
   Tablet Responsive
   ============================================ */
@media (max-width: 992px) {
    .woocommerce ul.products.columns-4,
    .woocommerce ul.products.columns-5,
    .woocommerce ul.products.columns-6 {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (max-width: 768px) {
    .woocommerce ul.products {
        gap: 20px !important;
    }
    
    .woocommerce ul.products.columns-3,
    .woocommerce ul.products.columns-4,
    .woocommerce ul.products.columns-5,
    .woocommerce ul.products.columns-6 {
        grid-template-columns: repeat(1, 1fr) !important;
    }
    
    .cpc-card {
        border-radius: 12px !important;
    }
    
    .cpc-content {
        padding: 14px !important;
    }
    
    .cpc-title {
        font-size: 14px !important;
    }
    
    .cpc-price-incl {
        font-size: 16px !important;
    }
    
    .cpc-brand-badge {
        padding: 4px 8px !important;
    }
    
    .cpc-brand-image {
        max-width: 50px !important;
        max-height: 22px !important;
    }
}

/* ============================================
   Mobile Responsive
   ============================================ */
@media (max-width: 480px) {
    .woocommerce ul.products {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }
    
    .cpc-card {
        border-radius: 10px !important;
    }
    
    .cpc-image-container {
        padding-bottom: 70% !important;
    }
    
    .cpc-content {
        padding: 12px !important;
    }
    
    .cpc-sku {
        font-size: 9px !important;
    }
    
    .cpc-title {
        font-size: 13px !important;
        margin-bottom: 8px !important;
    }
    
    .cpc-price-incl {
        font-size: 15px !important;
    }
    
    .cpc-price-excl {
        font-size: 11px !important;
    }
    
    .cpc-price del {
        font-size: 11px !important;
    }
    
    .cpc-delivery {
        padding: 8px 10px !important;
        font-size: 11px !important;
        margin-bottom: 10px !important;
    }
    
    .cpc-delivery i {
        font-size: 12px !important;
    }
    
    .cpc-tag {
        padding: 4px 8px !important;
        font-size: 8px !important;
        top: 10px !important;
        right: 10px !important;
    }
    
    .cpc-brand-badge {
        top: 10px !important;
        left: 10px !important;
        padding: 4px 6px !important;
    }
    
    .cpc-brand-image {
        max-width: 40px !important;
        max-height: 18px !important;
    }
    
    .cpc-spec-label {
        font-size: 8px !important;
    }
    
    .cpc-spec-value {
        font-size: 11px !important;
    }
    
    .cpc-spec-item {
        padding: 8px 4px !important;
    }
    
    .cpc-footer {
        padding-top: 10px !important;
    }
    
    .cpc-stock {
        font-size: 10px !important;
    }
    
    .cpc-stock-dot {
        width: 6px !important;
        height: 6px !important;
    }
    
    .cpc-add-to-cart,
    .cpc-view-more,
    .cpc-contact-btn {
        width: 34px !important;
        height: 34px !important;
        font-size: 12px !important;
    }
    
    .cpc-details-link {
        font-size: 12px !important;
    }
    
    .cpc-nav-prev,
    .cpc-nav-next {
        width: 28px !important;
        height: 28px !important;
        font-size: 10px !important;
        bottom: 12px !important;
    }
    
    .cpc-nav-prev { left: 10px !important; }
    .cpc-nav-next { right: 10px !important; }
    
    .cpc-image-dots {
        bottom: 10px !important;
        gap: 6px !important;
    }
    
    .cpc-dot {
        width: 6px !important;
        height: 6px !important;
    }
    
    .cpc-dot.active {
        width: 18px !important;
    }
}

/* ============================================
   Print Styles
   ============================================ */
@media print {
    .cpc-card {
        break-inside: avoid !important;
        box-shadow: none !important;
        border: 1px solid #ddd !important;
    }
    
    .cpc-nav-prev,
    .cpc-nav-next,
    .cpc-image-dots {
        display: none !important;
    }
}