/**
 * AISales Shared Components
 *
 * Shared styles for components used across multiple admin pages:
 * - Store Context Button & Panel
 * - Balance Indicator
 *
 * @package AISales_Sales_Manager
 */

/* ==========================================================================
   Header Buttons (Shared Base)
   ========================================================================== */

.aisales-header-btn,
.aisales-store-context-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--aisales-space-2);
	padding: var(--aisales-space-2) var(--aisales-space-4);
	background: var(--aisales-bg-white);
	border: 1px solid var(--aisales-border);
	border-radius: var(--aisales-radius-full);
	font-size: var(--aisales-font-sm);
	font-weight: var(--aisales-font-weight-medium);
	color: var(--aisales-text-secondary);
	cursor: pointer;
	transition: all var(--aisales-transition-fast);
	box-shadow: var(--aisales-shadow-xs);
}

.aisales-header-btn:hover,
.aisales-store-context-btn:hover {
	border-color: var(--aisales-primary);
	color: var(--aisales-primary);
	box-shadow: var(--aisales-shadow-sm);
}

.aisales-header-btn:focus,
.aisales-store-context-btn:focus {
	outline: none;
	border-color: var(--aisales-primary);
	box-shadow: 0 0 0 2px var(--aisales-primary-light);
}

.aisales-header-btn .dashicons,
.aisales-store-context-btn .dashicons {
	font-size: 16px;
	width: 16px;
	height: 16px;
	line-height: 1;
}

.aisales-store-name {
	max-width: 150px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Context Status Indicator */
.aisales-context-status {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	flex-shrink: 0;
}

.aisales-context-status--configured {
	background: var(--aisales-success);
	box-shadow: 0 0 0 2px var(--aisales-success-light);
}

.aisales-context-status--partial {
	background: var(--aisales-warning);
	box-shadow: 0 0 0 2px var(--aisales-warning-light);
}

.aisales-context-status--missing {
	background: var(--aisales-border);
	box-shadow: 0 0 0 2px var(--aisales-bg-muted);
}

/* Header Button Text Elements */
.aisales-header-btn__text {
	max-width: 100px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* ==========================================================================
   Balance Indicator
   ========================================================================== */

.aisales-balance-indicator {
	display: inline-flex;
	align-items: center;
	gap: var(--aisales-space-2);
	padding: var(--aisales-space-2) var(--aisales-space-4);
	background: var(--aisales-bg-white);
	border: 1px solid var(--aisales-border-light);
	border-radius: var(--aisales-radius-full);
	font-size: var(--aisales-font-sm);
	font-weight: var(--aisales-font-weight-medium);
	color: var(--aisales-text-secondary);
	box-shadow: var(--aisales-shadow-xs);
	transition: all var(--aisales-transition-fast);
}

.aisales-balance-indicator:hover {
	border-color: var(--aisales-primary);
	box-shadow: var(--aisales-shadow-sm);
}

.aisales-balance-indicator .dashicons {
	font-size: 16px;
	width: 16px;
	height: 16px;
	color: var(--aisales-success);
	line-height: 1;
}

.aisales-balance-indicator__count {
	font-weight: var(--aisales-font-weight-bold);
	color: var(--aisales-text-primary);
	transition: color 0.3s ease;
}

/* Balance animation states */
.aisales-balance-indicator.aisales-balance--decreasing .aisales-balance-indicator__count {
	color: var(--aisales-danger, #dc3545);
}

.aisales-balance-indicator.aisales-balance--increasing .aisales-balance-indicator__count {
	color: var(--aisales-success, #28a745);
}

/* Subtle pulse animation during count */
.aisales-balance-indicator.aisales-balance--decreasing,
.aisales-balance-indicator.aisales-balance--increasing {
	animation: aisales-balance-pulse 0.3s ease-in-out;
}

@keyframes aisales-balance-pulse {
	0% { transform: scale(1); }
	50% { transform: scale(1.05); }
	100% { transform: scale(1); }
}

/* ==========================================================================
   Store Context Panel (Slide-out)
   ========================================================================== */

.aisales-context-panel {
	position: fixed;
	inset: 0;
	z-index: 100001;
	visibility: hidden;
	pointer-events: none;
}

.aisales-context-panel--open {
	visibility: visible;
	pointer-events: auto;
}

.aisales-context-panel__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	opacity: 0;
	transition: opacity 0.3s ease;
}

.aisales-context-panel--open .aisales-context-panel__backdrop {
	opacity: 1;
}

.aisales-context-panel__content {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 420px;
	max-width: 100%;
	background: var(--aisales-bg-white);
	box-shadow: var(--aisales-shadow-xl);
	transform: translateX(100%);
	transition: transform 0.3s ease;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.aisales-context-panel--open .aisales-context-panel__content {
	transform: translateX(0);
}

.aisales-context-panel__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--aisales-space-4) var(--aisales-space-5);
	border-bottom: 1px solid var(--aisales-border-light);
	background: var(--aisales-bg-muted);
}

.aisales-context-panel__header h2 {
	display: flex;
	align-items: center;
	gap: var(--aisales-space-2);
	margin: 0;
	font-size: var(--aisales-font-lg);
	font-weight: var(--aisales-font-weight-semibold);
	color: var(--aisales-text-primary);
}

.aisales-context-panel__header h2 .dashicons {
	font-size: 20px;
	width: 20px;
	height: 20px;
	color: var(--aisales-primary);
}

.aisales-context-panel__close {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	background: transparent;
	border: none;
	border-radius: var(--aisales-radius-md);
	color: var(--aisales-text-muted);
	cursor: pointer;
	transition: all var(--aisales-transition-fast);
}

.aisales-context-panel__close:hover {
	background: var(--aisales-bg-white);
	color: var(--aisales-text-primary);
}

.aisales-context-panel__close .dashicons {
	font-size: 20px;
	width: 20px;
	height: 20px;
}

.aisales-context-panel__body {
	flex: 1;
	overflow-y: auto;
	padding: var(--aisales-space-5);
}

.aisales-context-panel__intro {
	margin: 0 0 var(--aisales-space-5);
	padding: var(--aisales-space-3) var(--aisales-space-4);
	background: var(--aisales-info-light);
	border-radius: var(--aisales-radius-md);
	font-size: var(--aisales-font-sm);
	color: var(--aisales-text-secondary);
	line-height: 1.5;
}

.aisales-context-panel__footer {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: var(--aisales-space-3);
	padding: var(--aisales-space-4) var(--aisales-space-5);
	border-top: 1px solid var(--aisales-border-light);
	background: var(--aisales-bg-muted);
}

/* Body class when panel is open */
body.aisales-context-panel-active {
	overflow: hidden;
}

/* ==========================================================================
   Context Form
   ========================================================================== */

.aisales-context-form {
	display: flex;
	flex-direction: column;
	gap: var(--aisales-space-5);
}

.aisales-context-field {
	display: flex;
	flex-direction: column;
	gap: var(--aisales-space-2);
}

.aisales-context-field > label {
	font-size: var(--aisales-font-sm);
	font-weight: var(--aisales-font-weight-semibold);
	color: var(--aisales-text-primary);
}

.aisales-context-field input[type="text"],
.aisales-context-field textarea,
.aisales-context-field select {
	width: 100%;
	padding: var(--aisales-space-3);
	background: var(--aisales-bg-white);
	border: 1px solid var(--aisales-border);
	border-radius: var(--aisales-radius-md);
	font-size: var(--aisales-font-sm);
	color: var(--aisales-text-primary);
	transition: border-color var(--aisales-transition-fast), box-shadow var(--aisales-transition-fast);
}

.aisales-context-field input[type="text"]:focus,
.aisales-context-field textarea:focus,
.aisales-context-field select:focus {
	outline: none;
	border-color: var(--aisales-primary);
	box-shadow: 0 0 0 2px var(--aisales-primary-light);
}

.aisales-context-field input::placeholder,
.aisales-context-field textarea::placeholder {
	color: var(--aisales-text-muted);
}

.aisales-context-field textarea {
	resize: vertical;
	min-height: 60px;
}

/* Brand Tone Options */
.aisales-tone-options {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--aisales-space-2);
}

.aisales-tone-option {
	position: relative;
	cursor: pointer;
}

.aisales-tone-option input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.aisales-tone-option__content {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--aisales-space-1);
	padding: var(--aisales-space-3) var(--aisales-space-2);
	background: var(--aisales-bg-muted);
	border: 2px solid transparent;
	border-radius: var(--aisales-radius-md);
	font-size: var(--aisales-font-xs);
	color: var(--aisales-text-secondary);
	text-align: center;
	transition: all var(--aisales-transition-fast);
}

.aisales-tone-option:hover .aisales-tone-option__content {
	background: var(--aisales-bg-white);
	border-color: var(--aisales-border);
}

.aisales-tone-option input:checked + .aisales-tone-option__content {
	background: var(--aisales-primary-light);
	border-color: var(--aisales-primary);
	color: var(--aisales-primary);
}

.aisales-tone-option__content .dashicons {
	font-size: 20px;
	width: 20px;
	height: 20px;
}

/* Sync Section */
.aisales-context-sync {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--aisales-space-3) var(--aisales-space-4);
	background: var(--aisales-bg-muted);
	border-radius: var(--aisales-radius-md);
	margin-top: var(--aisales-space-2);
}

.aisales-context-sync__info {
	font-size: var(--aisales-font-xs);
	color: var(--aisales-text-muted);
}

#aisales-sync-status {
	font-weight: var(--aisales-font-weight-medium);
	color: var(--aisales-text-secondary);
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

@media (max-width: 782px) {
	.aisales-store-context-btn .aisales-store-name,
	.aisales-header-btn__text {
		display: none;
	}

	.aisales-header-btn,
	.aisales-store-context-btn,
	.aisales-balance-indicator {
		padding: var(--aisales-space-2) var(--aisales-space-3);
	}

	.aisales-context-panel__content {
		width: 100%;
	}

	.aisales-tone-options {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ==========================================================================
   Balance Indicator - Clickable State
   ========================================================================== */

.aisales-balance-indicator--clickable {
	cursor: pointer;
}

.aisales-balance-indicator--clickable:focus {
	outline: none;
	border-color: var(--aisales-primary);
	box-shadow: 0 0 0 2px var(--aisales-primary-light);
}

.aisales-balance-indicator--clickable:active {
	transform: scale(0.98);
}

/* Low balance warning state */
.aisales-balance-indicator--low {
	border-color: var(--aisales-warning);
	background: linear-gradient(135deg, var(--aisales-bg-white) 0%, rgba(219, 166, 23, 0.05) 100%);
}

.aisales-balance-indicator--low .dashicons {
	color: var(--aisales-warning);
}

.aisales-balance-indicator--low .aisales-balance-indicator__count,
.aisales-balance-indicator--low #aisales-balance-display {
	color: var(--aisales-warning);
}

/* ==========================================================================
   Balance Modal
   ========================================================================== */

.aisales-balance-modal-overlay {
	z-index: 100002;
}

.aisales-balance-modal {
	z-index: 100003;
	max-width: 420px;
	width: 95%;
}

.aisales-balance-modal__header {
	background: linear-gradient(135deg, var(--aisales-bg-muted) 0%, var(--aisales-bg-white) 100%);
}

.aisales-balance-modal__header .aisales-modal__title {
	display: flex;
	align-items: center;
	gap: var(--aisales-space-2);
}

.aisales-balance-modal__header .aisales-modal__title .dashicons {
	color: var(--aisales-primary);
}

/* Current Balance Display */
.aisales-balance-current {
	text-align: center;
	padding: var(--aisales-space-5);
	background: linear-gradient(135deg, var(--aisales-bg-muted) 0%, var(--aisales-bg-white) 100%);
	border-radius: var(--aisales-radius-lg);
	margin-bottom: var(--aisales-space-5);
}

.aisales-balance-current__label {
	font-size: var(--aisales-font-sm);
	color: var(--aisales-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: var(--aisales-space-2);
}

.aisales-balance-current__amount {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: var(--aisales-space-2);
}

.aisales-balance-current__value {
	font-size: var(--aisales-font-display);
	font-weight: var(--aisales-font-weight-bold);
	color: var(--aisales-text-primary);
	line-height: 1;
}

.aisales-balance-current__unit {
	font-size: var(--aisales-font-base);
	color: var(--aisales-text-muted);
}

/* Low balance state */
.aisales-balance-current--low {
	background: linear-gradient(135deg, rgba(219, 166, 23, 0.1) 0%, var(--aisales-bg-white) 100%);
	border: 1px solid var(--aisales-warning-light);
}

.aisales-balance-current--low .aisales-balance-current__value {
	color: var(--aisales-warning);
}

.aisales-balance-current__warning {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--aisales-space-1);
	margin-top: var(--aisales-space-3);
	padding: var(--aisales-space-2) var(--aisales-space-3);
	background: var(--aisales-warning-light);
	border-radius: var(--aisales-radius-md);
	font-size: var(--aisales-font-xs);
	color: var(--aisales-warning);
}

.aisales-balance-current__warning .dashicons {
	font-size: 14px;
	width: 14px;
	height: 14px;
}

/* Progress Bar */
.aisales-balance-progress {
	height: 6px;
	background: var(--aisales-border-light);
	border-radius: var(--aisales-radius-full);
	overflow: hidden;
	margin-top: var(--aisales-space-4);
}

.aisales-balance-progress__bar {
	height: 100%;
	background: linear-gradient(90deg, var(--aisales-success) 0%, var(--aisales-primary) 100%);
	border-radius: var(--aisales-radius-full);
	transition: width 0.5s ease;
	min-width: 4px;
}

.aisales-balance-current--low .aisales-balance-progress__bar {
	background: linear-gradient(90deg, var(--aisales-warning) 0%, var(--aisales-danger) 100%);
}

.aisales-balance-progress__labels {
	display: flex;
	justify-content: space-between;
	margin-top: var(--aisales-space-1);
	font-size: var(--aisales-font-xs);
	color: var(--aisales-text-muted);
}

/* Divider */
.aisales-balance-modal__divider {
	position: relative;
	text-align: center;
	margin: var(--aisales-space-5) 0;
}

.aisales-balance-modal__divider::before {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	top: 50%;
	height: 1px;
	background: var(--aisales-border-light);
}

.aisales-balance-modal__divider span {
	position: relative;
	padding: 0 var(--aisales-space-3);
	background: var(--aisales-bg-white);
	font-size: var(--aisales-font-sm);
	font-weight: var(--aisales-font-weight-semibold);
	color: var(--aisales-text-secondary);
}

/* Package Grid */
.aisales-package-grid {
	display: flex;
	justify-content: center;
	margin-bottom: var(--aisales-space-5);
}

/* Package Card */
.aisales-package-card {
	flex: 1;
	max-width: 280px;
	padding: var(--aisales-space-5);
	background: var(--aisales-bg-white);
	border: 2px solid var(--aisales-border);
	border-radius: var(--aisales-radius-lg);
	text-align: center;
	cursor: pointer;
	transition: all var(--aisales-transition-fast);
}

.aisales-package-card:hover {
	border-color: var(--aisales-primary);
	box-shadow: var(--aisales-shadow-md);
	transform: translateY(-2px);
}

.aisales-package-card--selected {
	border-color: var(--aisales-primary);
	background: linear-gradient(135deg, var(--aisales-primary-light) 0%, var(--aisales-bg-white) 100%);
	box-shadow: 0 0 0 3px var(--aisales-primary-light);
}

.aisales-package-card__tokens {
	margin-bottom: var(--aisales-space-3);
}

.aisales-package-card__amount {
	display: block;
	font-size: var(--aisales-font-2xl);
	font-weight: var(--aisales-font-weight-bold);
	color: var(--aisales-text-primary);
	line-height: 1.2;
}

.aisales-package-card__unit {
	display: block;
	font-size: var(--aisales-font-sm);
	color: var(--aisales-text-muted);
}

.aisales-package-card__price {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 2px;
	margin-bottom: var(--aisales-space-2);
}

.aisales-package-card__currency {
	font-size: var(--aisales-font-lg);
	font-weight: var(--aisales-font-weight-semibold);
	color: var(--aisales-success);
}

.aisales-package-card__value {
	font-size: var(--aisales-font-xl);
	font-weight: var(--aisales-font-weight-bold);
	color: var(--aisales-success);
}

.aisales-package-card__rate {
	font-size: var(--aisales-font-xs);
	color: var(--aisales-text-muted);
}

/* Usage Estimates */
.aisales-usage-estimates {
	padding: var(--aisales-space-4);
	background: var(--aisales-bg-muted);
	border-radius: var(--aisales-radius-md);
}

.aisales-usage-estimates__title {
	font-size: var(--aisales-font-sm);
	font-weight: var(--aisales-font-weight-semibold);
	color: var(--aisales-text-primary);
	margin-bottom: var(--aisales-space-3);
	text-align: center;
}

.aisales-usage-estimates__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--aisales-space-3);
}

.aisales-usage-estimate {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--aisales-space-1);
}

.aisales-usage-estimate .dashicons {
	font-size: 20px;
	width: 20px;
	height: 20px;
	color: var(--aisales-primary);
}

.aisales-usage-estimate__value {
	font-size: var(--aisales-font-lg);
	font-weight: var(--aisales-font-weight-bold);
	color: var(--aisales-text-primary);
}

.aisales-usage-estimate__label {
	font-size: var(--aisales-font-xs);
	color: var(--aisales-text-muted);
	line-height: 1.3;
}

/* Modal Footer */
.aisales-balance-modal__footer {
	background: var(--aisales-bg-muted);
}

.aisales-balance-modal__footer .aisales-modal__info {
	display: flex;
	align-items: center;
	gap: var(--aisales-space-1);
}

.aisales-balance-modal__footer .aisales-modal__info .dashicons {
	font-size: 14px;
	width: 14px;
	height: 14px;
	color: var(--aisales-success);
}

/* Loading State */
.aisales-balance-modal__loading {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--aisales-space-3);
	background: rgba(255, 255, 255, 0.95);
	border-radius: var(--aisales-radius-lg);
	z-index: 1;
}

.aisales-balance-modal__spinner .spinner {
	float: none;
	margin: 0;
}

.aisales-balance-modal__loading-text {
	font-size: var(--aisales-font-sm);
	color: var(--aisales-text-secondary);
}

/* Purchase Button */
#aisales-purchase-btn {
	display: flex;
	align-items: center;
	gap: var(--aisales-space-2);
	padding: var(--aisales-space-3) var(--aisales-space-5);
}

#aisales-purchase-btn .dashicons {
	font-size: 16px;
	width: 16px;
	height: 16px;
}

/* Responsive */
@media (max-width: 480px) {
	.aisales-balance-modal {
		max-width: 100%;
		margin: var(--aisales-space-3);
	}

	.aisales-usage-estimates__grid {
		grid-template-columns: 1fr;
		gap: var(--aisales-space-2);
	}

	.aisales-usage-estimate {
		flex-direction: row;
		justify-content: flex-start;
		gap: var(--aisales-space-2);
	}

	.aisales-usage-estimate__label {
		text-align: left;
	}
}

/* ==========================================================================
   Reusable UI Components
   ========================================================================== */

/* Status Badges */
.aisales-status-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--aisales-space-1);
	padding: var(--aisales-space-1) var(--aisales-space-2);
	font-size: var(--aisales-font-xs);
	font-weight: var(--aisales-font-weight-medium);
	border-radius: var(--aisales-radius-full);
}

.aisales-status-badge .dashicons {
	font-size: 14px;
	width: 14px;
	height: 14px;
}

.aisales-status-badge--active,
.aisales-status-badge--success {
	background: var(--aisales-success-light);
	color: var(--aisales-success);
}

.aisales-status-badge--draft,
.aisales-status-badge--warning {
	background: var(--aisales-warning-light);
	color: #996b00;
}

.aisales-status-badge--none {
	background: var(--aisales-bg-muted);
	color: var(--aisales-text-muted);
}

/* Toggle Switch */
.aisales-toggle-switch {
	position: relative;
	display: inline-block;
	width: 44px;
	height: 24px;
	margin-left: auto;
}

.aisales-toggle-switch input {
	opacity: 0;
	width: 0;
	height: 0;
}

.aisales-toggle-switch__slider {
	position: absolute;
	cursor: pointer;
	inset: 0;
	background: var(--aisales-border);
	border-radius: var(--aisales-radius-full);
	transition: background 0.3s ease;
}

.aisales-toggle-switch__slider::before {
	position: absolute;
	content: "";
	height: 18px;
	width: 18px;
	left: 3px;
	bottom: 3px;
	background: var(--aisales-bg-white);
	border-radius: 50%;
	transition: transform 0.3s ease;
	box-shadow: var(--aisales-shadow-sm);
}

.aisales-toggle-switch input:checked + .aisales-toggle-switch__slider {
	background: var(--aisales-success);
}

.aisales-toggle-switch input:checked + .aisales-toggle-switch__slider::before {
	transform: translateX(20px);
}

.aisales-toggle-switch input:focus + .aisales-toggle-switch__slider {
	box-shadow: 0 0 0 2px var(--aisales-primary-light);
}

/* Spinner */
.aisales-spinner {
	width: 24px;
	height: 24px;
	border: 2px solid var(--aisales-border-light);
	border-top-color: var(--aisales-primary);
	border-radius: 50%;
	animation: aisales-spin 0.8s linear infinite;
}

.aisales-spinner--lg {
	width: 40px;
	height: 40px;
	border-width: 3px;
}

@keyframes aisales-spin {
	to { transform: rotate(360deg); }
}

/* Danger Button Modifier */
.aisales-btn--danger {
	color: var(--aisales-danger, #dc3545);
}

.aisales-btn--danger:hover {
	background: rgba(220, 53, 69, 0.1);
}
