/**
 * Shared EchoDash Component Styles
 * Common styles used across multiple components
 */

/* Design Tokens */
:root {

	/* Colors */
	--ecd-color-primary: #202e41;
	--ecd-color-secondary: #0a0079;
	--ecd-color-accent: #0c00ff;
	--ecd-color-text: #23282d;
	--ecd-color-text-light: #646970;
	--ecd-color-text-lighter: #8c8f94;
	--ecd-color-border: #c3c4c7;
	--ecd-color-border-light: #d2d5d9;
	--ecd-color-border-lighter: #e3e6ef;
	--ecd-color-background: #fff;
	--ecd-color-background-light: #f6f7f7;
	--ecd-color-background-lighter: #f8f9fc;
	--ecd-color-success: #46b450;
	--ecd-color-error: #d54e21;
	--ecd-color-focus: #007cba;
	--ecd-color-hover: #135e96;

	/* Spacing */
	--ecd-spacing-xs: 4px;
	--ecd-spacing-sm: 8px;
	--ecd-spacing-md: 12px;
	--ecd-spacing-lg: 16px;
	--ecd-spacing-xl: 20px;
	--ecd-spacing-2xl: 24px;
	--ecd-spacing-3xl: 30px;

	/* Border Radius */
	--ecd-radius-sm: 4px;
	--ecd-radius-md: 6px;
	--ecd-radius-lg: 8px;

	/* Icon Sizes */
	--ecd-icon-sm: 16px;
	--ecd-icon-md: 24px;
	--ecd-icon-lg: 32px;
	--ecd-icon-xl: 48px;

	/* Typography */
	--ecd-font-size-sm: 12px;
	--ecd-font-size-base: 13px;
	--ecd-font-size-md: 14px;
	--ecd-font-size-lg: 16px;
	--ecd-font-size-xl: 18px;
	--ecd-font-size-2xl: 20px;
	--ecd-font-size-3xl: 24px;

	/* Shadows */
	--ecd-shadow-sm: 0 0 48px 0 #0000001a;
	--ecd-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.15);
	--ecd-shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.2);
	--ecd-shadow-dropdown: 0 3px 5px rgb(0 0 0 / 13%);
}

.wrap {
	max-width: 1200px;
}

/* Base Form Input Styles */
.echodash-input-base {
	border: 1px solid var(--ecd-color-border-light);
	border-radius: var(--ecd-radius-lg);
	padding: 6px var(--ecd-spacing-md);
	font-size: var(--ecd-font-size-base);
	transition: border-color 0.2s ease;
	background-color: var(--ecd-color-background);
	color: var(--ecd-color-text);
}

/* Input Wrapper - Flexbox container for input + button */
.echodash-input-wrapper {
	position: relative;
	display: flex;
	align-items: center;
}

.echodash-input-base:focus {
	border-color: var(--ecd-color-focus);
	outline: none;
	box-shadow: 0 0 0 1px var(--ecd-color-focus);
}

.echodash-input-base:focus-visible {
	outline: 2px solid var(--ecd-color-focus);
	outline-offset: 2px;
}

.echodash-input-base:disabled {
	background-color: var(--ecd-color-background-light);
	color: #50575e;
	cursor: not-allowed;
}

/* Global Button Styles */
a.echodash-button,
button.echodash-button {
	background: transparent;
	border: 1px solid var(--ecd-color-border-light);
	color: var(--ecd-color-primary);
	text-decoration: none;
	padding: var(--ecd-spacing-md) var(--ecd-spacing-xl);
	border-radius: var(--ecd-radius-md);
	font-size: var(--ecd-font-size-md);
	font-weight: 500;
	transition: background-color 0.4s ease, color 0.4s ease, border-color 0.4s ease;
	cursor: pointer;
	display: inline-block;
}

a.echodash-button:hover,
button.echodash-button:hover {
	background-color: var(--ecd-color-primary);
	color: var(--ecd-color-background);
}

/* Focus-visible for keyboard navigation */
a.echodash-button:focus-visible,
button.echodash-button:focus-visible {
	outline: 2px solid var(--ecd-color-primary);
	outline-offset: 2px;
}

a.echodash-button span.dashicons,
button.echodash-button span.dashicons {
	margin-right: var(--ecd-spacing-xs);
}

a.echodash-button-primary,
button.echodash-button-primary {
	background-color: var(--ecd-color-primary);
	color: var(--ecd-color-background);
	border-color: var(--ecd-color-primary);
}

a.echodash-button-primary:hover,
button.echodash-button-primary:hover {
	text-decoration: underline;
}

/* Disabled button styles */
a.echodash-button[aria-disabled="true"],
button.echodash-button:disabled {
	background-color: var(--ecd-color-background-light);
	color: var(--ecd-color-text-lighter);
	border-color: var(--ecd-color-border-lighter);
	cursor: not-allowed;
	opacity: 0.6;
	pointer-events: none;
}

a.echodash-button:disabled:hover,
button.echodash-button:disabled:hover {
	background-color: var(--ecd-color-background-light);
	color: var(--ecd-color-text-lighter);
	border-color: var(--ecd-color-border-lighter);
	text-decoration: none;
}

a.echodash-button-primary:disabled,
button.echodash-button-primary:disabled {
	background-color: var(--ecd-color-text-lighter);
	color: var(--ecd-color-background);
	border-color: var(--ecd-color-text-lighter);
}

a.echodash-button-primary:disabled:hover,
button.echodash-button-primary:disabled:hover {
	background-color: var(--ecd-color-text-lighter);
	color: var(--ecd-color-background);
	border-color: var(--ecd-color-text-lighter);
	text-decoration: none;
}

/* Icon Styles */
.echodash-integration-item__icon {
	width: var(--ecd-icon-xl);
	height: var(--ecd-icon-xl);
	overflow: hidden;
	border-radius: var(--ecd-radius-lg);
	border: 1px solid #202e4133;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-right: var(--ecd-spacing-lg);
	background-color: var(--ecd-color-background);
}

.echodash-integration-item__icon-image {
	width: var(--ecd-icon-lg);
	height: var(--ecd-icon-lg);
	object-fit: contain;
}

/* Header Styles */
.echodash-header {
	display: flex;
	align-items: center;
	padding: var(--ecd-spacing-2xl) var(--ecd-spacing-xs);
}

.echodash-header__logo {
	font-size: 36px;
	margin-right: 10px;
}

.echodash-header__title {
	margin: 0;
}

.echodash-header__docs-link {
	margin-left: auto;
}

/* Common Card/Panel Styles */
.echodash-card {
	background-color: var(--ecd-color-background);
	border: 1px solid var(--ecd-color-border);
	border-radius: var(--ecd-radius-lg);
	box-shadow: var(--ecd-shadow-sm);
	padding: var(--ecd-spacing-xl);
}

/* Integration Item */
.echodash-integration-item {
	display: flex;
	align-items: center;
	padding: var(--ecd-spacing-lg);
	border-radius: var(--ecd-radius-sm);
	margin-bottom: var(--ecd-spacing-sm);
	transition: border-color 0.2s ease;
	border: 1px solid var(--ecd-color-border-lighter);
}

.echodash-integration-item:hover {
	border-color: #b4b7c1;
}

/* Loading animations */
@keyframes spin {

	from {
		transform: rotate(0deg);
	}

	to {
		transform: rotate(360deg);
	}
}

.ecd-spinner {
	animation: spin 1s linear infinite;
}

/* Prevent text decoration on spinner icons in buttons */
a.echodash-button .ecd-spinner,
button.echodash-button .ecd-spinner {
	text-decoration: none !important;
}

/* Ringing bell */

.ecd-ring {
	-webkit-animation: ecd-ring 4s 0s ease-in-out;
	-webkit-transform-origin: 50% 4px;
	transform-origin: 50% 4px;
	-moz-animation: ecd-ring 4s 0s ease-in-out;
	-moz-transform-origin: 50% 4px;
	animation: ecd-ring 4s 0s ease-in-out;
}

@-webkit-keyframes ecd-ring {

	0% {
		-webkit-transform: rotateZ(0);
	}

	1% {
		-webkit-transform: rotateZ(30deg);
	}

	3% {
		-webkit-transform: rotateZ(-28deg);
	}

	5% {
		-webkit-transform: rotateZ(34deg);
	}

	7% {
		-webkit-transform: rotateZ(-32deg);
	}

	9% {
		-webkit-transform: rotateZ(30deg);
	}

	11% {
		-webkit-transform: rotateZ(-28deg);
	}

	13% {
		-webkit-transform: rotateZ(26deg);
	}

	15% {
		-webkit-transform: rotateZ(-24deg);
	}

	17% {
		-webkit-transform: rotateZ(22deg);
	}

	19% {
		-webkit-transform: rotateZ(-20deg);
	}

	21% {
		-webkit-transform: rotateZ(18deg);
	}

	23% {
		-webkit-transform: rotateZ(-16deg);
	}

	25% {
		-webkit-transform: rotateZ(14deg);
	}

	27% {
		-webkit-transform: rotateZ(-12deg);
	}

	29% {
		-webkit-transform: rotateZ(10deg);
	}

	31% {
		-webkit-transform: rotateZ(-8deg);
	}

	33% {
		-webkit-transform: rotateZ(6deg);
	}

	35% {
		-webkit-transform: rotateZ(-4deg);
	}

	37% {
		-webkit-transform: rotateZ(2deg);
	}

	39% {
		-webkit-transform: rotateZ(-1deg);
	}

	41% {
		-webkit-transform: rotateZ(1deg);
	}

	43% {
		-webkit-transform: rotateZ(0);
	}

	100% {
		-webkit-transform: rotateZ(0);
	}
}

@-moz-keyframes ecd-ring {

	0% {
		-moz-transform: rotate(0);
	}

	1% {
		-moz-transform: rotate(30deg);
	}

	3% {
		-moz-transform: rotate(-28deg);
	}

	5% {
		-moz-transform: rotate(34deg);
	}

	7% {
		-moz-transform: rotate(-32deg);
	}

	9% {
		-moz-transform: rotate(30deg);
	}

	11% {
		-moz-transform: rotate(-28deg);
	}

	13% {
		-moz-transform: rotate(26deg);
	}

	15% {
		-moz-transform: rotate(-24deg);
	}

	17% {
		-moz-transform: rotate(22deg);
	}

	19% {
		-moz-transform: rotate(-20deg);
	}

	21% {
		-moz-transform: rotate(18deg);
	}

	23% {
		-moz-transform: rotate(-16deg);
	}

	25% {
		-moz-transform: rotate(14deg);
	}

	27% {
		-moz-transform: rotate(-12deg);
	}

	29% {
		-moz-transform: rotate(10deg);
	}

	31% {
		-moz-transform: rotate(-8deg);
	}

	33% {
		-moz-transform: rotate(6deg);
	}

	35% {
		-moz-transform: rotate(-4deg);
	}

	37% {
		-moz-transform: rotate(2deg);
	}

	39% {
		-moz-transform: rotate(-1deg);
	}

	41% {
		-moz-transform: rotate(1deg);
	}

	43% {
		-moz-transform: rotate(0);
	}

	100% {
		-moz-transform: rotate(0);
	}
}

@keyframes ecd-ring {

	0% {
		transform: rotate(0);
	}

	1% {
		transform: rotate(30deg);
	}

	3% {
		transform: rotate(-28deg);
	}

	5% {
		transform: rotate(34deg);
	}

	7% {
		transform: rotate(-32deg);
	}

	9% {
		transform: rotate(30deg);
	}

	11% {
		transform: rotate(-28deg);
	}

	13% {
		transform: rotate(26deg);
	}

	15% {
		transform: rotate(-24deg);
	}

	17% {
		transform: rotate(22deg);
	}

	19% {
		transform: rotate(-20deg);
	}

	21% {
		transform: rotate(18deg);
	}

	23% {
		transform: rotate(-16deg);
	}

	25% {
		transform: rotate(14deg);
	}

	27% {
		transform: rotate(-12deg);
	}

	29% {
		transform: rotate(10deg);
	}

	31% {
		transform: rotate(-8deg);
	}

	33% {
		transform: rotate(6deg);
	}

	35% {
		transform: rotate(-4deg);
	}

	37% {
		transform: rotate(2deg);
	}

	39% {
		transform: rotate(-1deg);
	}

	41% {
		transform: rotate(1deg);
	}

	43% {
		transform: rotate(0);
	}

	100% {
		transform: rotate(0);
	}
}

/* Respect user's reduced motion preferences for accessibility */
@media (prefers-reduced-motion: reduce) {

	.ecd-spinner {
		animation: none;
	}

	.ecd-ring {
		animation: none;
	}
}
