/**
 * PhoneEase Fixed Position Widget Styles
 *
 * Styles for the floating voice widget ([phoneease_widget] shortcode).
 * Includes 5 widget states: idle, listening, thinking, speaking, error.
 *
 * @package    PhoneEase
 * @since      0.11.76
 */

/* ===========================
   WIDGET CONTAINER
   =========================== */

.phoneease-widget {
	position: fixed;
	z-index: 999999;
	display: flex;
	flex-direction: column;
	align-items: center;
}

/* Position variants */
.phoneease-widget.position-bottom-right {
	bottom: 20px;
	right: 20px;
}

.phoneease-widget.position-bottom-left {
	bottom: 20px;
	left: 20px;
}

/* Mobile responsive - reduce spacing */
@media (max-width: 768px) {
	.phoneease-widget.position-bottom-right {
		bottom: 15px;
		right: 15px;
	}

	.phoneease-widget.position-bottom-left {
		bottom: 15px;
		left: 15px;
	}
}

/* ===========================
   WIDGET BUTTON
   =========================== */

.phoneease-widget-button {
	position: relative;
	width: var(--widget-size, 60px);
	height: var(--widget-size, 60px);
	border-radius: 50%;
	background-color: var(--widget-bg-color, #0073aa);
	color: var(--widget-icon-color, #ffffff);
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	transition: all 0.3s ease;
	padding: 0;
	outline: none;
}

.phoneease-widget-button:hover {
	transform: scale(1.05);
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

.phoneease-widget-button:active {
	transform: scale(0.98);
}

.phoneease-widget-button:focus {
	outline: 2px solid var(--widget-bg-color, #0073aa);
	outline-offset: 2px;
}

/* Ensure touch targets are at least 44px */
@media (max-width: 768px) {
	.phoneease-widget-button {
		min-width: 44px;
		min-height: 44px;
	}
}

/* ===========================
   ICONS
   =========================== */

.phoneease-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	opacity: 0;
	transition: opacity 0.3s ease;
}

/* Show phone icon by default (idle state) */
.phoneease-widget:not(.state-listening):not(.state-thinking):not(.state-speaking):not(.state-error) .phoneease-icon-phone {
	opacity: 1;
}

/* Show microphone icon ONLY when listening */
.phoneease-widget.state-listening .phoneease-icon-microphone {
	opacity: 1;
	color: #ffffff;
}

/* Show spinner when thinking */
.phoneease-widget.state-thinking .phoneease-icon-spinner {
	opacity: 1;
	animation: phoneease-spin 1s linear infinite;
}

/* Show soundwave when speaking */
.phoneease-widget.state-speaking .phoneease-icon-soundwave {
	opacity: 1;
}

/* Show phone icon with red color when error (fallback) */
.phoneease-widget.state-error .phoneease-icon-phone {
	opacity: 1;
	color: #e74c3c;
}

/* ===========================
   SOUNDWAVE ANIMATION
   =========================== */

.phoneease-icon-soundwave {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 3px;
}

.phoneease-icon-soundwave span {
	width: 3px;
	background-color: currentColor;
	border-radius: 2px;
	animation: phoneease-soundwave 1s ease-in-out infinite;
}

.phoneease-icon-soundwave span:nth-child(1) {
	height: 8px;
	animation-delay: 0s;
}

.phoneease-icon-soundwave span:nth-child(2) {
	height: 14px;
	animation-delay: 0.2s;
}

.phoneease-icon-soundwave span:nth-child(3) {
	height: 10px;
	animation-delay: 0.4s;
}

@keyframes phoneease-soundwave {
	0%, 100% {
		transform: scaleY(1);
	}
	50% {
		transform: scaleY(1.5);
	}
}

/* ===========================
   SPINNER ANIMATION
   =========================== */

@keyframes phoneease-spin {
	from {
		transform: translate(-50%, -50%) rotate(0deg);
	}
	to {
		transform: translate(-50%, -50%) rotate(360deg);
	}
}

/* ===========================
   PULSE ANIMATION (LISTENING STATE)
   =========================== */

.phoneease-pulse-ring {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: var(--widget-size, 60px);
	height: var(--widget-size, 60px);
	border-radius: 50%;
	border: 2px solid #e74c3c;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease;
}

.phoneease-widget.state-listening .phoneease-pulse-ring {
	opacity: 1;
	animation: phoneease-pulse 1.5s ease-out infinite;
}

@keyframes phoneease-pulse {
	0% {
		transform: translate(-50%, -50%) scale(1);
		opacity: 0.8;
	}
	100% {
		transform: translate(-50%, -50%) scale(1.5);
		opacity: 0;
	}
}

/* ===========================
   STATUS TOOLTIP
   =========================== */

.phoneease-widget-tooltip {
	position: absolute;
	bottom: calc(100% + 10px);
	left: 50%;
	transform: translateX(-50%);
	background-color: rgba(0, 0, 0, 0.85);
	color: #ffffff;
	padding: 8px 12px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 500;
	white-space: normal;
	max-width: min(280px, calc(100vw - 24px));
	text-align: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease;
	z-index: 10;
}

.phoneease-widget-tooltip::after {
	content: '';
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 6px solid transparent;
	border-top-color: rgba(0, 0, 0, 0.85);
}

/* Keep tooltip inside viewport for edge-pinned widget positions */
.phoneease-widget.position-bottom-right .phoneease-widget-tooltip {
	left: auto;
	right: 0;
	transform: none;
	text-align: left;
}

.phoneease-widget.position-bottom-right .phoneease-widget-tooltip::after {
	left: auto;
	right: calc((var(--widget-size, 60px) / 2) - 6px);
	transform: none;
}

.phoneease-widget.position-bottom-left .phoneease-widget-tooltip {
	left: 0;
	right: auto;
	transform: none;
	text-align: left;
}

.phoneease-widget.position-bottom-left .phoneease-widget-tooltip::after {
	left: calc((var(--widget-size, 60px) / 2) - 6px);
	transform: none;
}

/* Show tooltip on hover (idle state only) */
.phoneease-widget:not(.state-listening):not(.state-thinking):not(.state-speaking):not(.state-error) .phoneease-widget-button:hover + .phoneease-widget-tooltip {
	opacity: 1;
}

/* Update tooltip text based on state */
.phoneease-widget.state-listening .phoneease-tooltip-text::before {
	content: attr(data-listening-text);
}

.phoneease-widget.state-thinking .phoneease-tooltip-text::before {
	content: attr(data-thinking-text);
}

.phoneease-widget.state-speaking .phoneease-tooltip-text::before {
	content: attr(data-speaking-text);
}

.phoneease-widget.state-error .phoneease-tooltip-text::before {
	content: attr(data-error-text);
}

/* ===========================
   BRANDING
   =========================== */

.phoneease-branding {
	margin-top: 8px;
	font-size: 10px;
	color: #666666;
	text-align: center;
}

.phoneease-branding a {
	color: #666666;
	text-decoration: none;
	transition: color 0.2s ease;
}

.phoneease-branding a:hover {
	color: #0073aa;
}

/* Hide branding on Pro plan */
.phoneease-pro .phoneease-branding {
	display: none;
}

/* ===========================
   STATE COLORS
   =========================== */

/* Listening state - red button */
.phoneease-widget.state-listening .phoneease-widget-button {
	background-color: #e74c3c;
}

/* Error state - red button with shake */
.phoneease-widget.state-error .phoneease-widget-button {
	background-color: #e74c3c;
	animation: phoneease-shake 0.5s ease;
}

@keyframes phoneease-shake {
	0%, 100% {
		transform: translateX(0);
	}
	25% {
		transform: translateX(-5px);
	}
	75% {
		transform: translateX(5px);
	}
}

/* ===========================
   ACCESSIBILITY
   =========================== */

/* High contrast mode support */
@media (prefers-contrast: high) {
	.phoneease-widget-button {
		border: 2px solid currentColor;
	}
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
	.phoneease-widget-button,
	.phoneease-icon,
	.phoneease-pulse-ring,
	.phoneease-widget-tooltip {
		transition: none;
		animation: none;
	}
}

/* ===========================
   MOBILE OPTIMIZATIONS
   =========================== */

@media (max-width: 768px) {
	.phoneease-widget-tooltip {
		font-size: 12px;
		padding: 6px 10px;
	}

	.phoneease-branding {
		font-size: 9px;
	}
}
