/**
 * DPF Subscriptions - Public CSS
 *
 * Minimal styles using WooCommerce CSS classes.
 * This file provides only the necessary overrides and enhancements
 * that WooCommerce/theme styles don't cover.
 */

/**
 * DPF Subscriptions Product Grid
 *
 * Custom grid layout for subscription products.
 * Other styling is inherited from WooCommerce/theme.
 */

.green {
	color: var(--e-global-color-primary);
}


/* Grid Layout */
ul.products.dpf-subscriptions-products {
	display: grid;
	gap: 30px;
	margin: 30px 0;
	padding: 0;
	list-style: none;
}

/* Column variations */
ul.products.dpf-subscriptions-products.columns-1 {
	grid-template-columns: 1fr;
}

ul.products.dpf-subscriptions-products.columns-2 {
	grid-template-columns: repeat(2, 1fr);
}

ul.products.dpf-subscriptions-products.columns-3 {
	grid-template-columns: repeat(3, 1fr);
}

ul.products.dpf-subscriptions-products.columns-4 {
	grid-template-columns: repeat(4, 1fr);
}

ul.products.dpf-subscriptions-products.columns-5 {
	grid-template-columns: repeat(5, 1fr);
}

ul.products.dpf-subscriptions-products.columns-6 {
	grid-template-columns: repeat(6, 1fr);
}

/* Reset WooCommerce default product widths since we use CSS grid */
ul.products.dpf-subscriptions-products li.product {
	width: 100%;
	margin: 0;
	float: none;
	padding: 4% 4% 8% 4%;
    border: 1px solid #e5e5e5;
    border-radius: 15px;
	background-color: white;
}

#dpf-ideforum-subscription-container ul.products.dpf-subscriptions-products li.product {
	background-color: #f4f4f4;
}

.dpf-subscription-description ul{
    text-align: left !important;
    max-width: 90%;
    margin-left: 7.5%;
}

/* Tablet Responsive (max 1024px) - 2 columns */
@media screen and (max-width: 1024px) {
	ul.products.dpf-subscriptions-products.columns-3,
	ul.products.dpf-subscriptions-products.columns-4,
	ul.products.dpf-subscriptions-products.columns-5,
	ul.products.dpf-subscriptions-products.columns-6 {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* Mobile Responsive (max 767px) - 1 column */
@media screen and (max-width: 767px) {
	ul.products.dpf-subscriptions-products,
	ul.products.dpf-subscriptions-products.columns-2,
	ul.products.dpf-subscriptions-products.columns-3,
	ul.products.dpf-subscriptions-products.columns-4,
	ul.products.dpf-subscriptions-products.columns-5,
	ul.products.dpf-subscriptions-products.columns-6 {
		grid-template-columns: 1fr;
		gap: 20px;
	}

	ul.products.dpf-subscriptions-products {
		margin: 20px 0;
	}
}

/* Center product content */
.dpf-subscriptions-products li.dpf-subscription-product {
	text-align: center;
}

.dpf-subscriptions-products li.dpf-subscription-product img {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.dpf-subscriptions-products h2 {
	text-align: center;
	display: block;
}

/* Price display - two lines */
.dpf-subscriptions-products .dpf-subscription-price {
	text-align: center;
	display: block;
	margin: 0.5em 0;
}

.dpf-subscriptions-products .dpf-price-excl-vat {
	display: block;
	font-size: 1.25em;
	font-weight: 600;
	color: #77a464;
}

.dpf-subscriptions-products .dpf-price-incl-vat {
	display: block;
	font-size: 0.85em;
	color: #666666;
	margin-top: 0.25em;
}

.dpf-subscriptions-products h2 {
	margin-left: 4rem;
    margin-right: 4rem;
}

/* Variation description */
.dpf-subscriptions-products .dpf-subscription-description {
	text-align: center;
    font-size: 0.9em;
    color: #666666;
    margin: 0.5rem;
    line-height: 1.5;
}

/* Ensure button is full width for consistency */
.dpf-subscriptions-products .dpf-subscription-add-to-cart {
	width: 50%;
	text-align: center;
	color: #ffffff;
    font-family: var(--e-global-typography-accent-font-family), Sans-serif;
    font-size: var(--e-global-typography-accent-font-size);
    font-weight: var(--e-global-typography-accent-font-weight);
    border-style: solid;
    border-width: 0px 0px 0px 0px;
    border-radius: 25px 25px 25px 25px;
    padding: 14px 035px 14px 35px;
    background-color: var(--e-global-color-primary);
    border-color: #000000;
    display: block;
    margin-top: 1rem;
    margin-left: 25%;
	transition: 0.3s;
}

.dpf-subscriptions-products .dpf-subscription-add-to-cart:hover {
    transform: scale(1.1);
}

/* Loading State - custom since WooCommerce doesn't handle our AJAX */
.dpf-subscription-add-to-cart.loading {
	opacity: 0.7;
	pointer-events: none;
	position: relative;
}

.dpf-subscription-add-to-cart.loading::after {
	content: '';
	display: inline-block;
	width: 16px;
	height: 16px;
	border: 2px solid transparent;
	border-top-color: currentColor;
	border-radius: 50%;
	animation: dpf-spin 0.8s linear infinite;
	margin-left: 8px;
	vertical-align: middle;
}

/* Added State - custom success indicator */
.dpf-subscription-add-to-cart.added {
	background-color: #5cb85c;
	border-color: #5cb85c;
}

.dpf-subscription-add-to-cart.added::after {
	content: '✓';
	margin-left: 8px;
}

/* Spin Animation */
@keyframes dpf-spin {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}

/* Error Message */
.dpf-subscription-error-message {
	color: #cc0000;
	font-size: 0.875em;
	margin: 0.5em 0 0 0;
	text-align: center;
}

/* General Error Message (when products can't load) */
.dpf-subscriptions-error {
	padding: 1.5em;
	background: #f8f8f8;
	border: 1px solid #e0e0e0;
	border-radius: 4px;
	color: #666666;
	text-align: center;
}