/**
 * WC Account Customizer - Frontend Styles
 * Modern, beautiful CSS for WooCommerce My Account customization
 */

/* ==========================================================================
   1. BASE & RESET
   ========================================================================== */

.wcac {
	font-family: var(--wcac-font, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif);
	font-size: var(--wcac-text-size, 15px);
	line-height: var(--wcac-line-height, 1.6);
	color: var(--wcac-text, #2D3436);
	box-sizing: border-box;
}

.wcac *,
.wcac *::before,
.wcac *::after {
	box-sizing: inherit;
}

/* ==========================================================================
   2. LAYOUT - Sidebar
   ========================================================================== */

.wcac[data-layout="sidebar"] {
	display: flex;
	gap: var(--wcac-spacing, 24px);
}

.wcac[data-layout="sidebar"] .woocommerce-MyAccount-navigation {
	flex-shrink: 0;
	width: 240px;
}

.wcac[data-layout="sidebar"] .woocommerce-MyAccount-content {
	flex: 1;
	min-width: 0;
}

/* ==========================================================================
   3. LAYOUT - Horizontal Tabs
   ========================================================================== */

.wcac[data-layout="horizontal-tabs"] {
	display: flex;
	flex-direction: column;
	gap: var(--wcac-spacing, 24px);
}

.wcac[data-layout="horizontal-tabs"] .woocommerce-MyAccount-navigation ul {
	display: flex;
	flex-direction: row;
	overflow-x: auto;
	gap: var(--wcac-tab-gap, 8px);
	border-bottom: 1px solid var(--wcac-border, #E9ECEF);
	padding-bottom: 0;
}

/* ==========================================================================
   4. LAYOUT - Vertical Tabs
   ========================================================================== */

.wcac[data-layout="vertical-tabs"] {
	display: flex;
	gap: var(--wcac-spacing, 24px);
}

.wcac[data-layout="vertical-tabs"] .woocommerce-MyAccount-navigation {
	flex-shrink: 0;
	width: 220px;
	border-right: 1px solid var(--wcac-border, #E9ECEF);
	padding-right: var(--wcac-spacing, 24px);
}

/* ==========================================================================
   5. LAYOUT - Pills
   ========================================================================== */

.wcac[data-layout="pills"] .woocommerce-MyAccount-navigation ul {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wcac-tab-gap, 8px);
}

.wcac[data-layout="pills"] .woocommerce-MyAccount-navigation li a {
	background: var(--wcac-surface, #F8F9FA);
	border-radius: var(--wcac-tab-radius, 10px);
	padding: 8px 16px;
	transition: all 0.2s ease;
}

.wcac[data-layout="pills"] .woocommerce-MyAccount-navigation li.is-active a {
	background: var(--wcac-primary, #6C5CE7);
	color: #fff;
}

/* ==========================================================================
   6. NAVIGATION STYLES
   ========================================================================== */

.wcac-nav,
.woocommerce-MyAccount-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.wcac-nav__item,
.woocommerce-MyAccount-navigation li {
	margin: 0;
}

.wcac-nav__item a,
.woocommerce-MyAccount-navigation li a {
	display: flex;
	align-items: center;
	padding: 12px 16px;
	color: var(--wcac-text, #2D3436);
	text-decoration: none;
	border-radius: var(--wcac-tab-radius, 10px);
	transition: all 0.2s ease;
	font-weight: 500;
}

.wcac-nav__item a:hover,
.woocommerce-MyAccount-navigation li a:hover {
	background: var(--wcac-surface, #F8F9FA);
	color: var(--wcac-primary, #6C5CE7);
}

.wcac-nav__item--active a,
.wcac-nav__item.is-active a,
.woocommerce-MyAccount-navigation li.is-active a {
	background: var(--wcac-primary, #6C5CE7);
	color: #fff;
}

.wcac-nav__icon {
	margin-right: 10px;
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.wcac-nav__icon svg {
	width: 100%;
	height: 100%;
}

/* ==========================================================================
   7. BUTTONS
   ========================================================================== */

.wcac-btn,
.wcac .button,
.wcac button[type="submit"],
.wcac input[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 22px;
	font-size: 15px;
	font-weight: 500;
	border-radius: var(--wcac-btn-radius, 8px);
	border: none;
	cursor: pointer;
	transition: all 0.25s ease;
	text-decoration: none;
	line-height: 1.4;
	background: var(--wcac-primary, #6C5CE7);
	color: #fff;
}

.wcac-btn:hover,
.wcac .button:hover {
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.wcac-btn--small {
	padding: 8px 16px;
	font-size: 13px;
}

.wcac-btn--large {
	padding: 14px 28px;
	font-size: 16px;
}

.wcac-btn--outlined {
	background: transparent;
	color: var(--wcac-primary, #6C5CE7);
	border: 2px solid var(--wcac-primary, #6C5CE7);
}

.wcac-btn--ghost {
	background: transparent;
	color: var(--wcac-primary, #6C5CE7);
}

/* ==========================================================================
   8. CARDS
   ========================================================================== */

.wcac-card {
	background: var(--wcac-bg, #fff);
	border-radius: var(--wcac-card-radius, 12px);
	padding: 24px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.wcac-card:hover {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
}

/* ==========================================================================
   9. WIDGETS
   ========================================================================== */

.wcac-widgets-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--wcac-spacing, 24px);
	margin-top: var(--wcac-spacing, 24px);
}

.wcac-widget-wrapper--full {
	grid-column: 1 / -1;
}

.wcac-widget-wrapper--half {
	grid-column: span 1;
}

.wcac-widget-wrapper--third {
	grid-column: span 1;
}

@media (min-width: 768px) {
	.wcac-widgets-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.wcac-widget-wrapper--third {
		grid-column: span 1;
	}
}

@media (min-width: 1024px) {
	.wcac-widgets-grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.wcac-widget-wrapper--half {
		grid-column: span 2;
	}
}

.wcac-widget {
	height: 100%;
}

.wcac-widget__inner {
	height: 100%;
	display: flex;
	flex-direction: column;
}

.wcac-widget__header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.wcac-widget__title {
	margin: 0;
	font-size: var(--wcac-heading-size, 18px);
	font-weight: 600;
	color: var(--wcac-text, #2D3436);
}

.wcac-widget__subtitle {
	margin: 4px 0 0;
	font-size: 14px;
	color: var(--wcac-text-secondary, #636E72);
}

.wcac-widget__content {
	flex: 1;
}

.wcac-widget__footer {
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid var(--wcac-border, #E9ECEF);
}

.wcac-widget__empty {
	color: var(--wcac-text-secondary, #636E72);
	font-style: italic;
}

/* Welcome Widget */
.wcac-widget--welcome .wcac-widget__header {
	flex-direction: row;
	align-items: center;
}

.wcac-widget__avatar {
	flex-shrink: 0;
}

.wcac-widget__avatar img {
	border-radius: 50%;
	width: 80px;
	height: 80px;
}

/* ==========================================================================
   10. ORDERS & DOWNLOADS
   ========================================================================== */

.wcac-orders-list,
.wcac-downloads-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.wcac-order-item,
.wcac-download-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px;
	background: var(--wcac-surface, #F8F9FA);
	border-radius: 8px;
	transition: background 0.2s ease;
}

.wcac-order-item:hover,
.wcac-download-item:hover {
	background: var(--wcac-border, #E9ECEF);
}

.wcac-order-item__main,
.wcac-download-item__main {
	flex: 1;
}

.wcac-order-item__number,
.wcac-download-item__name {
	font-weight: 600;
	color: var(--wcac-text, #2D3436);
	text-decoration: none;
	display: block;
	margin-bottom: 4px;
}

.wcac-order-item__number:hover {
	color: var(--wcac-primary, #6C5CE7);
}

.wcac-order-item__date,
.wcac-download-item__file {
	font-size: 13px;
	color: var(--wcac-text-secondary, #636E72);
}

.wcac-order-item__meta,
.wcac-download-item__actions {
	display: flex;
	align-items: center;
	gap: 12px;
}

.wcac-order-status {
	padding: 4px 12px;
	border-radius: 20px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.wcac-order-status--completed,
.wcac-order-status--processing {
	background: color-mix(in srgb, var(--wcac-success, #00B894) 15%, transparent);
	color: var(--wcac-success, #00B894);
}

.wcac-order-status--pending {
	background: color-mix(in srgb, var(--wcac-warning, #FDCB6E) 15%, transparent);
	color: #d39e00;
}

.wcac-order-status--cancelled,
.wcac-order-status--failed {
	background: color-mix(in srgb, var(--wcac-error, #D63031) 15%, transparent);
	color: var(--wcac-error, #D63031);
}

/* ==========================================================================
   11. INFO LISTS & STATS
   ========================================================================== */

.wcac-info-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.wcac-info-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--wcac-border, #E9ECEF);
}

.wcac-info-item:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.wcac-info-item__label {
	color: var(--wcac-text-secondary, #636E72);
	font-size: 14px;
}

.wcac-info-item__value {
	font-weight: 600;
	color: var(--wcac-text, #2D3436);
}

.wcac-stats-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: 16px;
}

.wcac-stat-item {
	text-align: center;
	padding: 20px;
	background: var(--wcac-surface, #F8F9FA);
	border-radius: 8px;
}

.wcac-stat-item__value {
	display: block;
	font-size: 28px;
	font-weight: 700;
	color: var(--wcac-primary, #6C5CE7);
	margin-bottom: 4px;
}

.wcac-stat-item__label {
	display: block;
	font-size: 13px;
	color: var(--wcac-text-secondary, #636E72);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

/* ==========================================================================
   12. ADDRESSES
   ========================================================================== */

.wcac-address-group {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
}

@media (min-width: 768px) {
	.wcac-address-group {
		grid-template-columns: repeat(2, 1fr);
	}
}

.wcac-address-item {
	padding: 16px;
	background: var(--wcac-surface, #F8F9FA);
	border-radius: 8px;
}

.wcac-address-item__title {
	margin: 0 0 12px;
	font-size: 14px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--wcac-text-secondary, #636E72);
}

.wcac-address-item__address {
	font-style: normal;
	color: var(--wcac-text, #2D3436);
	line-height: 1.6;
	margin-bottom: 12px;
}

.wcac-address-item__empty {
	color: var(--wcac-text-secondary, #636E72);
	font-style: italic;
}

/* ==========================================================================
   13. FORMS & FIELDS
   ========================================================================== */

.wcac-field {
	margin-bottom: 20px;
}

.wcac-field label {
	display: block;
	margin-bottom: 6px;
	font-weight: 500;
	color: var(--wcac-text, #2D3436);
}

.wcac-field label .required {
	color: var(--wcac-error, #D63031);
}

.wcac-field__input,
.wcac input[type="text"],
.wcac input[type="email"],
.wcac input[type="password"],
.wcac input[type="tel"],
.wcac input[type="date"],
.wcac input[type="number"],
.wcac input[type="url"],
.wcac textarea,
.wcac select {
	width: 100%;
	padding: 10px 14px;
	border: 1px solid var(--wcac-border, #E9ECEF);
	border-radius: 8px;
	font-size: 15px;
	font-family: inherit;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	background: var(--wcac-bg, #fff);
	color: var(--wcac-text, #2D3436);
}

.wcac-field__input:focus,
.wcac input:focus,
.wcac textarea:focus,
.wcac select:focus {
	outline: none;
	border-color: var(--wcac-primary, #6C5CE7);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--wcac-primary, #6C5CE7) 10%, transparent);
}

.wcac-field__description {
	display: block;
	margin-top: 4px;
	font-size: 13px;
	color: var(--wcac-text-secondary, #636E72);
}

.wcac-field__error {
	display: block;
	margin-top: 4px;
	font-size: 13px;
	color: var(--wcac-error, #D63031);
}

.wcac-field--checkbox label {
	display: flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
}

.wcac-field--checkbox input {
	width: auto;
	margin: 0;
}

.wcac-field__input--color {
	height: 50px;
	padding: 4px;
	cursor: pointer;
}

/* ==========================================================================
   14. LINKS
   ========================================================================== */

.wcac-link {
	color: var(--wcac-primary, #6C5CE7);
	text-decoration: none;
	font-weight: 500;
	transition: color 0.2s ease;
}

.wcac-link:hover {
	color: color-mix(in srgb, var(--wcac-primary, #6C5CE7) 80%, black);
	text-decoration: underline;
}

.wcac-link--small {
	font-size: 14px;
}

/* ==========================================================================
   15. ANIMATIONS
   ========================================================================== */

@keyframes wcac-fade-in {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

@keyframes wcac-slide-in {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes wcac-skeleton-pulse {
	0% {
		background-position: 200% 0;
	}
	100% {
		background-position: -200% 0;
	}
}

.wcac-skeleton {
	background: linear-gradient(
		90deg,
		var(--wcac-surface, #F8F9FA) 25%,
		var(--wcac-border, #E9ECEF) 50%,
		var(--wcac-surface, #F8F9FA) 75%
	);
	background-size: 200% 100%;
	animation: wcac-skeleton-pulse 1.5s ease-in-out infinite;
	border-radius: 6px;
	min-height: 20px;
}

/* ==========================================================================
   16. DARK MODE
   ========================================================================== */

[data-theme="dark"] .wcac,
@media (prefers-color-scheme: dark) {
	.wcac[data-dark-mode="auto"] {
		--wcac-text: #E0E0E0;
		--wcac-text-secondary: #888888;
		--wcac-bg: #1A1A2E;
		--wcac-surface: #16213E;
		--wcac-border: #2A2A4A;
	}
}

/* ==========================================================================
   17. RESPONSIVE
   ========================================================================== */

@media (max-width: 767px) {
	.wcac[data-layout="sidebar"],
	.wcac[data-layout="vertical-tabs"] {
		flex-direction: column;
	}

	.wcac[data-layout="sidebar"] .woocommerce-MyAccount-navigation,
	.wcac[data-layout="vertical-tabs"] .woocommerce-MyAccount-navigation {
		width: 100%;
		border-right: none;
		border-bottom: 1px solid var(--wcac-border, #E9ECEF);
		padding-right: 0;
		padding-bottom: var(--wcac-spacing, 24px);
	}

	.wcac[data-layout="sidebar"] .woocommerce-MyAccount-navigation ul,
	.wcac[data-layout="vertical-tabs"] .woocommerce-MyAccount-navigation ul {
		display: flex;
		overflow-x: auto;
		gap: 8px;
	}

	.wcac-widgets-grid {
		grid-template-columns: 1fr !important;
	}

	.wcac-widget-wrapper--half,
	.wcac-widget-wrapper--third {
		grid-column: 1 !important;
	}

	.wcac-address-group {
		grid-template-columns: 1fr !important;
	}
}

/* ==========================================================================
   18. UTILITIES
   ========================================================================== */

.wcac-hidden {
	display: none !important;
}

.wcac-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border-width: 0;
}
