/**
 * Ad Manager Pro - Public Ads Styles
 * 
 * Handles responsive scaling and safe margins for all ad containers.
 */

.amp-ad-container, .amp-carousel-container, .amp-slot-placeholder-box, .amp-slot-placeholder-container {
    box-sizing: border-box !important;
    max-width: 100%;
    min-width: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.amp-strict-responsive {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
}

.amp-strict-responsive img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
    object-fit: contain !important;
}

.amp-ad-container img {
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
}

.amp-has-safe-margin {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
}

@media (max-width: 768px) {
    .amp-ad-container {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }
}

/* Carousel specific styles */
.amp-carousel-container {
    position: relative !important;
    overflow: hidden !important;
    max-width: 100%;
    display: block !important;
}

.amp-carousel-arrow {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background-color: rgba(0, 0, 0, 0.4) !important;
    border: none !important;
    color: white !important;
    font-size: 18px !important;
    font-weight: bold !important;
    cursor: pointer !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 12 !important;
    transition: background-color 0.2s ease, opacity 0.2s ease !important;
    padding: 0 !important;
    line-height: 1 !important;
}

.amp-carousel-arrow:hover {
    background-color: rgba(0, 0, 0, 0.7) !important;
}

.amp-carousel-arrow-prev {
    left: 10px !important;
}

.amp-carousel-arrow-next {
    right: 10px !important;
}

@media (hover: hover) {
    .amp-carousel-container:hover .amp-carousel-arrow {
        display: flex !important;
    }
}

.amp-carousel-track {
    display: flex !important;
    width: 100% !important;
    height: 100% !important;
    transition: transform 0.5s ease-in-out !important;
}

.amp-carousel-slide {
    flex: 0 0 100% !important;
    width: 100% !important;
    height: 100% !important;
}

.amp-carousel-slide a {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    text-decoration: none !important;
}

.amp-carousel-slide img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    display: block !important;
}

.amp-carousel-dots {
    position: absolute !important;
    bottom: 10px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    display: flex !important;
    gap: 8px !important;
    z-index: 10 !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.amp-carousel-dot {
    width: 12px !important;
    height: 12px !important;
    border-radius: 50% !important;
    background-color: rgba(255, 255, 255, 0.5) !important;
    border: 1px solid rgba(0, 0, 0, 0.3) !important;
    cursor: pointer !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    transition: background-color 0.3s ease !important;
}

.amp-carousel-dot.activated {
    background-color: #0073aa !important;
}

