/* ========================================
   VAPESMALL - My Account Styles
   Clean, Modern & Premium Design
======================================== */

:root {
	--vs-primary: #FFAA01;
	--vs-primary-hover: #E69A00;
	--vs-secondary: #333333;
	--vs-accent: #034C8C;
	--vs-bg: #F5F5F5;
	--vs-white: #FFFFFF;
	--vs-text: #333333;
	--vs-text-light: #666666;
	--vs-text-muted: #999999;
	--vs-border: #E0E0E0;
	--vs-border-light: #F0F0F0;
	--vs-success: #28A745;
	--vs-warning: #FFC107;
	--vs-error: #DC3545;
	--vs-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
	--vs-shadow-hover: 0 8px 30px rgba(0, 0, 0, 0.12);
	--vs-radius: 12px;
	--vs-radius-sm: 8px;
	--vs-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

input{
	padding: 3px 6px;
}
fieldset{
	padding: 10px 20px;
	margin-bottom: 30px;
}
/* ========================================
   Auth Page Styles (Login/Register)
======================================== */

.vs-auth-wrapper {
	min-height: calc(100vh - 300px);
	padding: 60px 20px;
	/* background: linear-gradient(135deg, #FAFAFA 0%, #F0F0F0 100%); */
}

.vs-auth-container {
	max-width: 1400px;
	margin: 0 auto;
}

/* Auth Header */
.vs-auth-header {
	text-align: center;
	margin-bottom: 48px;
	animation: fadeInDown 0.5s ease;
}

@keyframes fadeInDown {
	from {
		opacity: 0;
		transform: translateY(-20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.vs-auth-page-title {
	font-family: 'AvenirLTStd-Black', sans-serif;
	font-size: 42px;
	font-weight: 900;
	color: var(--vs-secondary);
	margin: 0 0 12px;
	letter-spacing: -0.5px;
}

.vs-auth-subtitle {
	font-size: 17px;
	color: var(--vs-text-light);
	margin: 0;
}

/* Dual Layout */
.vs-auth-dual {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: start;
}

/* Single Layout */
.vs-auth-single {
	max-width: 992px;
	margin: 0 auto;
}

/* Auth Card */
.vs-auth-card {
	background: var(--vs-white);
	border-radius: var(--vs-radius);
	box-shadow: var(--vs-shadow);
	overflow: hidden;
	transition: var(--vs-transition);
}

.vs-auth-card:hover {
	box-shadow: var(--vs-shadow-hover);
}

.vs-auth-card-inner {
	padding: 48px 40px;
}

.vs-single-card .vs-auth-card-inner {
	padding: 56px 48px;
	display: flex;
    flex-direction: row;
    gap: 30px;
}
.vs-auth-card-inner-signin{
	width: 56%;
}
/* Auth Title */
.vs-auth-title {
	font-family: 'AvenirLTStd-Black', sans-serif;
	font-size: 28px;
	font-weight: 900;
	color: var(--vs-secondary);
	margin: 0 0 8px 0;
	text-align: center;
	letter-spacing: 1px;
}

.vs-auth-desc {
	font-size: 14px;
	color: var(--vs-text-muted);
	text-align: center;
	margin: 0 0 28px;
}

/* Social Login */
.vs-social-login {
	margin-bottom: 24px;
}

.vs-social-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	width: 100%;
	height: 52px;
	background: var(--vs-white);
	border: 2px solid var(--vs-border);
	border-radius: var(--vs-radius-sm);
	font-size: 15px;
	font-weight: 600;
	color: var(--vs-text);
	cursor: pointer;
	transition: var(--vs-transition);
}

.vs-social-btn:hover {
	border-color: var(--vs-text-light);
	background: var(--vs-bg);
	transform: translateY(-2px);
}

.vs-social-google:hover {
	border-color: #4285F4;
}

/* Divider */
.vs-divider {
	display: flex;
	align-items: center;
	margin-bottom: 24px;
}

.vs-divider::before,
.vs-divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--vs-border);
}

.vs-divider span {
	padding: 0 16px;
	font-size: 13px;
	color: var(--vs-text-muted);
	white-space: nowrap;
}

/* Register Benefits */
.vs-register-benefits {
	background: linear-gradient(135deg, #FFFBF0 0%, #FFF5E0 100%);
	border-radius: var(--vs-radius-sm);
	padding: 16px 20px;
	margin-bottom: 24px;
	border: 1px solid rgba(255, 170, 1, 0.2);
}

.vs-benefit-item {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--vs-text);
	padding: 6px 0;
}

.vs-benefit-item svg {
	stroke: var(--vs-success);
	flex-shrink: 0;
}

/* Input with Icon */
.vs-input-icon-wrapper {
	position: relative;
}

.vs-input-icon {
	position: absolute;
	left: 16px;
	/* top: 50%; */
	/* transform: translateY(-50%); */
	stroke: var(--vs-text-muted);
	pointer-events: none;
	transition: var(--vs-transition);
	top: 18px;
}

.vs-input-with-icon {
	padding-left: 48px !important;
}

.vs-input-icon-wrapper:focus-within .vs-input-icon,
.vs-password-wrapper:focus-within .vs-input-icon {
	stroke: var(--vs-primary);
}

/* Password Strength */
.vs-password-strength {
	margin-top: 12px;
}

.vs-strength-bar {
	height: 4px;
	background: var(--vs-border);
	border-radius: 2px;
	overflow: hidden;
	margin-bottom: 8px;
}

.vs-strength-fill {
	height: 100%;
	width: 0%;
	border-radius: 2px;
	transition: width 0.3s ease, background 0.3s ease;
}

.vs-strength-fill[data-strength="1"] {
	width: 25%;
	background: var(--vs-error);
}

.vs-strength-fill[data-strength="2"] {
	width: 50%;
	background: var(--vs-warning);
}

.vs-strength-fill[data-strength="3"] {
	width: 75%;
	background: #90CAF9;
}

.vs-strength-fill[data-strength="4"] {
	width: 100%;
	background: var(--vs-success);
}

.vs-strength-text {
	font-size: 12px;
	color: var(--vs-text-muted);
}

/* Password Requirements */
.vs-password-requirements {
	list-style: none;
	padding: 0;
	margin: 12px 0 0;
	display: grid;
	gap: 6px;
}

.vs-password-requirements li {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	color: var(--vs-text-muted);
	transition: var(--vs-transition);
}

.vs-password-requirements li svg {
	stroke: var(--vs-border);
	transition: var(--vs-transition);
}

.vs-password-requirements li.is-valid {
	color: var(--vs-success);
}

.vs-password-requirements li.is-valid svg {
	stroke: var(--vs-success);
}

/* Button Arrow */
.vs-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
}

.vs-btn-arrow {
	transition: transform 0.3s ease;
}

.vs-btn:hover .vs-btn-arrow {
	transform: translateX(4px);
}

.vs-password-wrapper .vs-input-icon {
	left: 16px;
}

/* Mobile Register Link */
.vs-mobile-register-link,
.vs-have-account-link {
	text-align: center;
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px solid var(--vs-border-light);
}

.vs-mobile-register-link p,
.vs-have-account-link p {
	font-size: 14px;
	color: var(--vs-text-muted);
	margin: 0;
}

.vs-mobile-register-link a,
.vs-have-account-link a {
	color: var(--vs-primary);
	font-weight: 600;
}

.vs-mobile-register-link a:hover,
.vs-have-account-link a:hover {
	text-decoration: underline;
}

/* Desktop hide mobile register link */
@media (min-width: 993px) {
	.vs-mobile-register-link {
		display: none;
	}
}

/* Register Prompt (when registration disabled) */
.vs-register-prompt {
	margin-top: 32px;
	text-align: center;    
	flex: 1;
}

.vs-prompt-divider {
	width: 60px;
	height: 2px;
	/* background: var(--vs-border); */
	margin: 0 auto 20px;
}

.vs-prompt-text {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	font-size: 14px;
	color: var(--vs-text-muted);
	margin: 0;
}

.vs-prompt-text svg {
	stroke: var(--vs-text-muted);
	flex-shrink: 0;
}

.vs-prompt-text a {
	color: var(--vs-primary);
	font-weight: 600;
}

.vs-prompt-text a:hover {
	text-decoration: underline;
}

/* Required Asterisk */
.required {
	color: var(--vs-error);
}

/* ========================================
   Register Page Specific Styles
======================================== */

.vs-register-page .vs-auth-single {
	max-width: 560px;
}

.vs-register-benefits-large {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-bottom: 32px;
	padding: 24px;
	background: linear-gradient(135deg, #FFFBF0 0%, #FFF5E0 100%);
	border-radius: var(--vs-radius);
	border: 1px solid rgba(255, 170, 1, 0.2);
}

.vs-register-benefits-large .vs-benefit-item {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	padding: 0;
}

.vs-benefit-icon {
	width: 48px;
	height: 48px;
	background: var(--vs-white);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.vs-benefit-icon svg {
	stroke: var(--vs-primary);
}

.vs-benefit-content {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.vs-benefit-content strong {
	font-size: 15px;
	font-weight: 700;
	color: var(--vs-text);
}

.vs-benefit-content span {
	font-size: 13px;
	color: var(--vs-text-muted);
}

/* Register CTA in Login Page */
.vs-register-cta {
	text-align: center;
	padding: 32px 24px;
	background: var(--vs-bg);
	border-radius: var(--vs-radius);
	margin-top: 24px;
}

.vs-register-cta h3 {
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-size: 20px;
	font-weight: 800;
	color: var(--vs-secondary);
	margin: 0 0 8px;
}

.vs-register-cta > p {
	font-size: 14px;
	color: var(--vs-text-muted);
	margin: 0 0 20px;
}

.vs-benefits-list {
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
	text-align: left;
	max-width: 280px;
	margin-left: auto;
	margin-right: auto;
}

.vs-benefits-list li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: var(--vs-text);
	padding: 8px 0;
}

.vs-benefits-list li svg {
	stroke: var(--vs-success);
	flex-shrink: 0;
}

.vs-btn-register {
	width: 100%;
	max-width: 280px;
}

/* Login Prompt */
.vs-login-prompt {
	text-align: center;
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px solid var(--vs-border-light);
}

.vs-login-prompt p {
	font-size: 14px;
	color: var(--vs-text-muted);
	margin: 0;
}

.vs-login-prompt a {
	color: var(--vs-primary);
	font-weight: 600;
}

.vs-login-prompt a:hover {
	text-decoration: underline;
}

/* Form Group */
.vs-form-group {
	margin-bottom: 24px;
}

.vs-label {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: var(--vs-text);
	margin-bottom: 8px;
	font-family: 'AvenirLTStd-Medium', sans-serif;
}

/* Input Styles */
.vs-input {
	width: 100%;
	height: 52px;
	padding: 0 18px;
	font-size: 16px;
	color: var(--vs-text);
	background: var(--vs-white);
	border: 2px solid var(--vs-border);
	border-radius: var(--vs-radius-sm);
	transition: var(--vs-transition);
	font-family: 'AvenirLTStd', sans-serif;
}

.vs-input:focus {
	outline: none;
	border-color: var(--vs-primary);
	box-shadow: 0 0 0 4px rgba(255, 170, 1, 0.15);
}

.vs-input::placeholder {
	color: var(--vs-text-muted);
}

/* Password Wrapper */
.vs-password-wrapper {
	position: relative;
}

.vs-password-wrapper .vs-input {
	padding-right: 50px;
}

.vs-toggle-password {
	position: absolute;
	right: 16px;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	cursor: pointer;
	color: var(--vs-text-muted);
	padding: 4px;
	transition: var(--vs-transition);
}

.vs-toggle-password:hover {
	color: var(--vs-primary);
}

.vs-password-hint {
	font-size: 12px;
	color: var(--vs-text-muted);
	margin: 8px 0 0;
}

/* Form Options */
.vs-form-options {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 28px;
}

/* Checkbox Styles */
.vs-checkbox-label {
	display: flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	font-size: 14px;
	color: var(--vs-text-light);
}

.vs-checkbox {
	display: none;
}

.vs-checkbox-custom {
	width: 20px;
	height: 20px;
	border: 2px solid var(--vs-border);
	border-radius: 4px;
	position: relative;
	transition: var(--vs-transition);
	flex-shrink: 0;
}

.vs-checkbox:checked + .vs-checkbox-custom {
	background: var(--vs-primary);
	border-color: var(--vs-primary);
}

.vs-checkbox:checked + .vs-checkbox-custom::after {
	content: '';
	position: absolute;
	left: 5px;
	top: 0;
	width: 5px;
	height: 10px;
	border: solid white;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

/* Forgot Link */
.vs-forgot-link {
	font-size: 14px;
	color: var(--vs-primary);
	font-weight: 600;
	transition: var(--vs-transition);
}

.vs-forgot-link:hover {
	color: var(--vs-primary-hover);
	text-decoration: underline;
}

/* Terms */
.vs-terms-agree {
	margin-bottom: 28px;
}

.vs-terms-agree a {
	color: var(--vs-primary);
	font-weight: 600;
}

.vs-terms-agree a:hover {
	text-decoration: underline;
}

/* Info Text */
.vs-info-text {
	font-size: 14px;
	color: var(--vs-text-light);
	background: var(--vs-bg);
	padding: 16px;
	border-radius: var(--vs-radius-sm);
	margin-bottom: 24px;
	align-items: center;
    display: flex;
    gap: 5px;
    line-height: 1.5;
}

/* Button Styles */
.vs-btn,
.vs-form-submit input[type="submit"] {
	display: block;
	width: 100%;
	height: 52px;
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-size: 15px;
	font-weight: 800;
	letter-spacing: 1px;
	border: none;
	border-radius: var(--vs-radius-sm);
	cursor: pointer;
	transition: var(--vs-transition);
	text-transform: uppercase;
}

.vs-btn-primary,
.vs-form-submit input[type="submit"] {
	background: var(--vs-primary);
	color: var(--vs-white);
}

.vs-btn-primary:hover,
.vs-form-submit input[type="submit"]:hover {
	background: var(--vs-primary-hover);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(255, 170, 1, 0.35);
}

.vs-btn-primary:active,
.vs-form-submit input[type="submit"]:active {
	transform: translateY(0);
}


.vs-btn-secondary {
	background: var(--vs-secondary);
	color: var(--vs-white);
	display: flex;
}

.vs-btn-secondary:hover {
	background: #444;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
}

/* Form Submit Container */
.vs-form-submit {
	margin: 28px 0 0;
}

/* ========================================
   My Account Page Styles
======================================== */

.vs-myaccount-wrapper {
	padding: 50px 20px 80px;
	background: var(--vs-white);
	min-height: calc(100vh - 200px);
}

.vs-myaccount-container {
	max-width: 1400px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 40px;
	align-items: start;
}

/* ========================================
   Account Navigation
======================================== */

.vs-account-nav {
	background: var(--vs-white);
	border-radius: var(--vs-radius);
	box-shadow: var(--vs-shadow);
	overflow: hidden;
	position: sticky;
	top: 120px;
}

/* User Card */
.vs-nav-user-card {
	padding: 28px 24px;
	background: linear-gradient(135deg, var(--vs-secondary) 0%, #444 100%);
	display: flex;
	align-items: center;
	gap: 16px;
}

.vs-nav-avatar {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	overflow: hidden;
	border: 3px solid rgba(255, 255, 255, 0.3);
	flex-shrink: 0;
}

.vs-nav-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.vs-nav-user-info {
	display: flex;
	flex-direction: column;
	gap: 4px;
	overflow: hidden;
}

.vs-nav-username {
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-size: 16px;
	font-weight: 800;
	color: var(--vs-white);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.vs-nav-email {
	font-size: 12px;
	color: rgba(255, 255, 255, 0.7);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Nav Menu */
.vs-nav-menu {
	list-style: none;
	margin: 0;
	padding: 16px 0;
}

.vs-nav-item {
	margin: 0;
}

.vs-nav-item a {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 24px;
	font-size: 15px;
	font-weight: 600;
	color: var(--vs-text-light);
	transition: var(--vs-transition);
	border-left: 3px solid transparent;
}

.vs-nav-item a:hover {
	background: var(--vs-bg);
	color: var(--vs-text);
	border-left-color: var(--vs-border);
}

.vs-nav-item.is-active a {
	background: linear-gradient(90deg, rgba(255, 170, 1, 0.1) 0%, transparent 100%);
	color: var(--vs-primary);
	border-left-color: var(--vs-primary);
	font-weight: 700;
}

.vs-nav-item a svg {
	width: 20px;
	height: 20px;
	stroke: currentColor;
	flex-shrink: 0;
}

/* Logout Item */
.vs-nav-customer-logout a {
	color: var(--vs-error);
}

.vs-nav-customer-logout a:hover {
	background: rgba(220, 53, 69, 0.08);
	color: var(--vs-error);
	border-left-color: var(--vs-error);
}

/* ========================================
   Account Content
======================================== */

.vs-account-content {
	background: var(--vs-white);
	border-radius: var(--vs-radius);
	box-shadow: var(--vs-shadow);
	padding: 40px;
	min-height: 500px;
}

/* ========================================
   Dashboard Styles
======================================== */

.vs-dashboard {
	animation: fadeIn 0.4s ease;
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Welcome Section */
.vs-dashboard-welcome {
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 32px;
	background: linear-gradient(135deg, #FFFBF0 0%, #FFF5E0 100%);
	border-radius: var(--vs-radius);
	margin-bottom: 32px;
	border: 1px solid rgba(255, 170, 1, 0.2);
}

.vs-welcome-avatar {
	position: relative;
	flex-shrink: 0;
}

.vs-welcome-avatar img {
	width: 88px;
	height: 88px;
	border-radius: 50%;
	object-fit: cover;
	border: 4px solid var(--vs-white);
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.vs-avatar-edit {
	position: absolute;
	bottom: 0;
	right: 0;
	width: 32px;
	height: 32px;
	background: var(--vs-primary);
	border: 3px solid var(--vs-white);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: var(--vs-transition);
}

.vs-avatar-edit:hover {
	background: var(--vs-primary-hover);
	transform: scale(1.1);
}

.vs-avatar-edit svg {
	stroke: var(--vs-white);
}

.vs-welcome-title {
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-size: 28px;
	margin: 0 0 8px;
	color: var(--vs-secondary);
}

.vs-welcome-title span {
	color: var(--vs-primary);
}

.vs-welcome-meta {
	margin: 0;
}

.vs-member-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 14px;
	color: var(--vs-text-light);
}

.vs-member-badge svg {
	color: var(--vs-primary);
}

/* Stats Section */
.vs-dashboard-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
	margin-bottom: 40px;
}

.vs-stat-card {
	background: var(--vs-bg);
	border-radius: var(--vs-radius-sm);
	padding: 24px;
	display: flex;
	align-items: center;
	gap: 16px;
	transition: var(--vs-transition);
}

.vs-stat-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--vs-shadow);
}

.vs-stat-icon {
	width: 52px;
	height: 52px;
	background: linear-gradient(135deg, var(--vs-primary) 0%, #FFB833 100%);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.vs-stat-icon svg {
	stroke: var(--vs-white);
}

.vs-stat-icon-wishlist {
	background: linear-gradient(135deg, #FF6B6B 0%, #FF8E8E 100%);
}

.vs-stat-icon-points {
	background: linear-gradient(135deg, #28A745 0%, #48C76A 100%);
}

.vs-stat-icon-coupons {
	background: linear-gradient(135deg, #6C5CE7 0%, #A29BFE 100%);
}

.vs-stat-content {
	display: flex;
	flex-direction: column;
}

.vs-stat-number {
	font-family: 'AvenirLTStd-Black', sans-serif;
	font-size: 28px;
	font-weight: 900;
	color: var(--vs-secondary);
	line-height: 1;
}

.vs-stat-label {
	font-size: 13px;
	color: var(--vs-text-muted);
	margin-top: 4px;
}

/* Quick Actions */
.vs-quick-actions {
	margin-bottom: 40px;
}

.vs-section-title {
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-size: 20px;
	font-weight: 800;
	color: var(--vs-secondary);
	margin: 0 0 20px;
}

.vs-action-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

.vs-action-card {
	background: var(--vs-white);
	border: 2px solid var(--vs-border-light);
	border-radius: var(--vs-radius-sm);
	padding: 24px 20px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	transition: var(--vs-transition);
	text-align: center;
}

.vs-action-card:hover {
	border-color: var(--vs-primary);
	transform: translateY(-3px);
	box-shadow: var(--vs-shadow);
}

.vs-action-icon {
	width: 48px;
	height: 48px;
	background: var(--vs-bg);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: var(--vs-transition);
}

.vs-action-card:hover .vs-action-icon {
	background: var(--vs-primary);
}

.vs-action-card:hover .vs-action-icon svg {
	stroke: var(--vs-white);
}

.vs-action-icon svg {
	stroke: var(--vs-text-light);
	transition: var(--vs-transition);
}

.vs-action-label {
	font-size: 14px;
	font-weight: 600;
	color: var(--vs-text);
}

.vs-action-shop {
	background: linear-gradient(135deg, #FFFBF0 0%, #FFF5E0 100%);
	border-color: rgba(255, 170, 1, 0.3);
}

.vs-action-shop .vs-action-icon {
	background: var(--vs-primary);
}

.vs-action-shop .vs-action-icon svg {
	stroke: var(--vs-white);
}

/* Recent Orders */
.vs-recent-orders {
	margin-bottom: 20px;
}

.vs-section-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 20px;
}

.vs-view-all {
	font-size: 14px;
	font-weight: 600;
	color: var(--vs-primary);
	transition: var(--vs-transition);
}

.vs-view-all:hover {
	color: var(--vs-primary-hover);
}

.vs-orders-table-wrapper {
	overflow-x: hidden;
}

.vs-orders-table {
	width: 100%;
	border-collapse: collapse;
}

.vs-orders-table th {
	text-align: left;
	padding: 14px 16px;
	font-size: 12px;
	font-weight: 700;
	color: var(--vs-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	background: var(--vs-bg);
	border-bottom: 2px solid var(--vs-border);
}

.vs-orders-table th:first-child {
	border-radius: var(--vs-radius-sm) 0 0 0;
}

.vs-orders-table th:last-child {
	border-radius: 0 var(--vs-radius-sm) 0 0;
}

.vs-orders-table td {
	padding: 18px 16px;
	font-size: 14px;
	color: var(--vs-text);
	border-bottom: 1px solid var(--vs-border-light);
}

.vs-orders-table tbody tr:hover {
	background: var(--vs-bg);
}

.vs-order-number strong {
	color: var(--vs-secondary);
	font-weight: 700;
}

.vs-order-date {
	color: var(--vs-text-light);
}

/* Status Badges */
.vs-status-badge {
	display: inline-block;
	padding: 6px 14px;
	font-size: 12px;
	font-weight: 700;
	border-radius: 20px;
	text-transform: capitalize;
}

.vs-status-pending {
	background: rgba(255, 193, 7, 0.15);
	color: #D99E00;
}

.vs-status-processing {
	background: rgba(3, 76, 140, 0.12);
	color: var(--vs-accent);
}

.vs-status-on-hold {
	background: rgba(108, 92, 231, 0.12);
	color: #6C5CE7;
}

.vs-status-completed {
	background: rgba(40, 167, 69, 0.12);
	color: var(--vs-success);
}

.vs-status-cancelled,
.vs-status-failed {
	background: rgba(220, 53, 69, 0.12);
	color: var(--vs-error);
}

.vs-status-refunded {
	background: rgba(153, 153, 153, 0.15);
	color: var(--vs-text-muted);
}

.vs-order-total {
	font-weight: 700;
	color: var(--vs-secondary);
}

.vs-btn-small {
	display: inline-block;
	padding: 8px 18px;
	font-size: 12px;
	font-weight: 700;
	color: var(--vs-white);
	background: var(--vs-secondary);
	border-radius: 6px;
	transition: var(--vs-transition);
}

.vs-btn-small:hover {
	background: var(--vs-primary);
	color: var(--vs-white);
}

/* Empty Orders */
.vs-empty-orders {
	text-align: center;
	padding: 60px 20px;
}

.vs-empty-icon {
	margin-bottom: 20px;
}

.vs-empty-orders h3 {
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-size: 22px;
	color: var(--vs-secondary);
	margin: 0 0 10px;
}

.vs-empty-orders p {
	color: var(--vs-text-light);
	margin: 0 0 28px;
}

.vs-empty-orders .vs-btn {
	width: max-content;
    margin: 0 auto;
    padding: 0 40px;
    display: flex;
}

/* ========================================
   WooCommerce Form Overrides
======================================== */

.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	color: var(--vs-secondary);
	margin-bottom: 24px;
}

.woocommerce-MyAccount-content .woocommerce-form-row {
	margin-bottom: 20px;
}

.woocommerce-MyAccount-content input[type="text"],
.woocommerce-MyAccount-content input[type="email"],
.woocommerce-MyAccount-content input[type="password"],
.woocommerce-MyAccount-content input[type="tel"],
.woocommerce-MyAccount-content select,
.woocommerce-MyAccount-content textarea {
	width: 100%;
	height: 48px;
	padding: 0 16px;
	font-size: 15px;
	color: var(--vs-text);
	background: var(--vs-white);
	border: 2px solid var(--vs-border);
	border-radius: var(--vs-radius-sm);
	transition: var(--vs-transition);
}

.woocommerce-MyAccount-content textarea {
	height: auto;
	min-height: 120px;
	padding: 14px 16px;
}

.woocommerce-MyAccount-content input:focus,
.woocommerce-MyAccount-content select:focus,
.woocommerce-MyAccount-content textarea:focus {
	outline: none;
	border-color: var(--vs-primary);
	box-shadow: 0 0 0 4px rgba(255, 170, 1, 0.15);
}

.woocommerce-MyAccount-content button[type="submit"],
.woocommerce-MyAccount-content .button {
	display: inline-block;
	padding: 14px 36px;
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-size: 14px;
	font-weight: 800;
	letter-spacing: 0.5px;
	color: var(--vs-white);
	background: var(--vs-primary);
	border: none;
	border-radius: var(--vs-radius-sm);
	cursor: pointer;
	transition: var(--vs-transition);
	text-transform: uppercase;
}

.woocommerce-MyAccount-content button[type="submit"]:hover,
.woocommerce-MyAccount-content .button:hover {
	background: var(--vs-primary-hover);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(255, 170, 1, 0.35);
}

/* WooCommerce Notices - 隐藏所有通知 */
/* .woocommerce-notices-wrapper {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	overflow: hidden !important;
} */

.woocommerce-message,
.woocommerce-info {
	background: linear-gradient(135deg, #F0FFF4 0%, #E6F9EA 100%);
	border: 1px solid rgba(40, 167, 69, 0.2);
	border-left: 4px solid var(--vs-success);
	border-radius: 10px;
	padding: 18px 24px;
	margin-bottom: 20px;
	color: #155724;
	display: flex;
	align-items: center;
	gap: 14px;
	font-size: 14px;
	line-height: 1.6;
	animation: slideInDown 0.4s ease;
	box-shadow: 0 4px 12px rgba(40, 167, 69, 0.12);
	position: relative;
	overflow: hidden;
}

/* 装饰性背景元素 */
.woocommerce-message::after {
	content: '';
	position: absolute;
	top: -50%;
	right: -10%;
	width: 150px;
	height: 150px;
	background: rgba(40, 167, 69, 0.05);
	border-radius: 50%;
	pointer-events: none;
}

@keyframes slideInDown {
	from {
		opacity: 0;
		transform: translateY(-20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.woocommerce-message::before {
	content: '✓';
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	min-width: 32px;
	background: linear-gradient(135deg, #28A745 0%, #218838 100%);
	color: white;
	border-radius: 50%;
	font-size: 16px;
	font-weight: bold;
	flex-shrink: 0;
	box-shadow: 0 2px 8px rgba(40, 167, 69, 0.3);
}

.woocommerce-info {
	background: linear-gradient(135deg, #FFFBF0 0%, #FFF5E0 100%);
	border: 1px solid rgba(255, 170, 1, 0.2);
	border-left: 4px solid var(--vs-primary);
	color: #856404;
}

.woocommerce-info::before {
	content: 'i';
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	min-width: 32px;
	background: linear-gradient(135deg, #FFAA01 0%, #E69A00 100%);
	color: white;
	border-radius: 50%;
	font-size: 16px;
	font-weight: bold;
	flex-shrink: 0;
	box-shadow: 0 2px 8px rgba(255, 170, 1, 0.3);
}

.woocommerce-error,
.woocommerce-error li {
	background: linear-gradient(135deg, #FFF5F5 0%, #FFE8E8 100%);
	border: 1px solid rgba(220, 53, 69, 0.2);
	border-left: 4px solid var(--vs-error);
	border-radius: 10px;
	padding: 18px 24px;
	margin-bottom: 20px;
	color: #DC3545;
	font-size: 14px;
	line-height: 1.6;
	list-style: none;
	animation: shake 0.5s ease, slideInDown 0.4s ease;
	box-shadow: 0 4px 12px rgba(220, 53, 69, 0.12);
	position: relative;
	overflow: hidden;
}

/* 装饰性背景元素 */
.woocommerce-error::after {
	content: '';
	position: absolute;
	top: -50%;
	right: -10%;
	width: 150px;
	height: 150px;
	background: rgba(220, 53, 69, 0.05);
	border-radius: 50%;
	pointer-events: none;
}

.woocommerce-error {
	padding: 0;
	background: transparent;
	border: none;
	box-shadow: none;
}

.woocommerce-error::after {
	display: none;
}

.woocommerce-error li {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	transition: all 0.3s ease;
}

.woocommerce-error li:hover {
	transform: translateX(4px);
}

.woocommerce-error li::before {
	content: '✕';
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	min-width: 32px;
	background: linear-gradient(135deg, #DC3545 0%, #C82333 100%);
	color: white;
	border-radius: 50%;
	font-size: 16px;
	font-weight: bold;
	margin-top: 0;
	box-shadow: 0 2px 8px rgba(220, 53, 69, 0.3);
	flex-shrink: 0;
}

.woocommerce-error li strong {
	font-weight: 700;
	color: #B02A37;
}

/* 移除所有可能的边框和轮廓 */

.woocommerce-error,
.woocommerce-message,
.woocommerce-info,
.woocommerce-notices-wrapper {
	outline: none !important;
	box-shadow: none !important;
}
/* .woocommerce-error {
	outline: none !important;
	box-shadow: none !important;
} */

/* 移除所有交互状态的边框 */

/* Button inside notice */
.woocommerce-message .button,
.woocommerce-info .button {
	margin-left: auto;
	padding: 10px 20px;
	font-size: 13px;
	background: linear-gradient(135deg, #333333 0%, #1A1A1A 100%);
	color: white;
	border-radius: 6px;
	font-weight: 600;
	border: none;
	cursor: pointer;
	transition: all 0.3s ease;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.woocommerce-message .button:hover,
.woocommerce-info .button:hover {
	background: linear-gradient(135deg, #FFAA01 0%, #E69A00 100%);
	color: white;
	transform: translateY(-2px);
	box-shadow: 0 4px 8px rgba(255, 170, 1, 0.3);
}

/* 通知关闭按钮 */
.woocommerce-message .woocommerce-notice-close,
.woocommerce-info .woocommerce-notice-close,
.woocommerce-error .woocommerce-notice-close {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 24px;
	height: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.05);
	border-radius: 50%;
	cursor: pointer;
	transition: all 0.3s ease;
	opacity: 0.6;
	font-size: 18px;
	line-height: 1;
	color: currentColor;
}

.woocommerce-message .woocommerce-notice-close:hover,
.woocommerce-info .woocommerce-notice-close:hover,
.woocommerce-error .woocommerce-notice-close:hover {
	opacity: 1;
	background: rgba(0, 0, 0, 0.1);
	transform: rotate(90deg);
}

.woocommerce-order-details th.product-name{
	text-align: left;
}
.woocommerce-order-details th.product-total,.woocommerce-order-details td.product-total,.woocommerce-order-details tfoot tr{
	text-align: right;
}
.woocommerce-order-details tr th,.woocommerce-order-details .product-name{
	padding-right: 8px;
}


/* ========================================
   Responsive Styles
======================================== */

@media (max-width: 1400px) {
	.vs-dashboard-stats {
		grid-template-columns: repeat(2, 1fr);
	}
	
	.vs-action-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 992px) {
	.vs-myaccount-container {
		grid-template-columns: 1fr;
	}
	
	.vs-account-nav {
		position: static;
	}
	
	.vs-nav-menu {
		display: flex;
		flex-wrap: wrap;
		padding: 12px;
		gap: 8px;
	}
	
	.vs-nav-item a {
		padding: 10px 16px;
		border-radius: var(--vs-radius-sm);
		border-left: none;
		background: var(--vs-bg);
	}
	
	.vs-nav-item.is-active a {
		background: var(--vs-primary);
		color: var(--vs-white);
		border-left: none;
	}
	
	.vs-account-content {
		padding: 28px;
	}
	
	.vs-auth-dual {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	.vs-auth-wrapper {
		padding: 30px 16px;
	}
	
	.vs-auth-card-inner {
		padding: 32px 24px;
	}
	
	.vs-auth-title {
		font-size: 24px;
	}
	
	.vs-myaccount-wrapper {
		padding: 24px 16px 60px;
	}
	
	.vs-dashboard-welcome {
		flex-direction: column;
		text-align: center;
		padding: 24px;
	}
	
	.vs-welcome-title {
		font-size: 22px;
	}
	
	.vs-dashboard-stats {
		grid-template-columns: 1fr 1fr;
		gap: 12px;
	}
	
	.vs-stat-card {
		padding: 16px;
		flex-direction: column;
		text-align: center;
	}
	
	.vs-stat-icon {
		width: 44px;
		height: 44px;
	}
	
	.vs-stat-number {
		font-size: 24px;
	}
	
	.vs-action-grid {
		grid-template-columns: 1fr 1fr;
		gap: 12px;
	}
	
	.vs-action-card {
		padding: 18px 14px;
	}
	
	.vs-orders-table th,
	.vs-orders-table td {
		padding: 12px 10px;
		font-size: 13px;
	}
	
	.vs-nav-user-card {
		flex-direction: column;
		text-align: center;
		padding: 24px 16px;
	}
}

@media (max-width: 480px) {
	.vs-form-options {
		flex-direction: column;
		gap: 16px;
		align-items: flex-start;
	}
	
	.vs-dashboard-stats {
		grid-template-columns: 1fr;
	}
	
	.vs-action-grid {
		grid-template-columns: 1fr;
	}
}

/* ========================================
   Loading States & Animations
======================================== */

.vs-btn.is-loading {
	pointer-events: none;
	opacity: 0.8;
}

.vs-spinner {
	display: inline-block;
	width: 16px;
	height: 16px;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-radius: 50%;
	border-top-color: #fff;
	animation: spin 0.8s linear infinite;
	margin-right: 8px;
	vertical-align: middle;
}

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

/* Form Group Focus Animation */
.vs-form-group.is-focused .vs-label {
	color: var(--vs-primary);
}

.vs-form-group.is-focused .vs-input {
	border-color: var(--vs-primary);
}

/* Input Shake Animation for Errors */
@keyframes shake {
	0%, 100% { transform: translateX(0); }
	10%, 30%, 50%, 70%, 90% { transform: translateX(-5px); }
	20%, 40%, 60%, 80% { transform: translateX(5px); }
}

.vs-input.has-error {
	border-color: var(--vs-error) !important;
	animation: shake 0.5s ease;
}

/* Card Hover Lift Effect */
.vs-auth-card {
	transform: translateY(0);
}

.vs-auth-card:hover {
	transform: translateY(-4px);
}

/* Gradient Text Effect */
.vs-welcome-title span {
	background: linear-gradient(135deg, var(--vs-primary) 0%, #FFB833 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

/* Tooltip Styles */
[data-tooltip] {
	position: relative;
}

[data-tooltip]::after {
	content: attr(data-tooltip);
	position: absolute;
	bottom: 100%;
	left: 50%;
	transform: translateX(-50%) translateY(-8px);
	padding: 8px 12px;
	background: var(--vs-secondary);
	color: var(--vs-white);
	font-size: 12px;
	border-radius: 6px;
	white-space: nowrap;
	opacity: 0;
	visibility: hidden;
	transition: var(--vs-transition);
	pointer-events: none;
}

[data-tooltip]:hover::after {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(-4px);
}

/* Custom Scrollbar */
.vs-account-content::-webkit-scrollbar,
.vs-orders-table-wrapper::-webkit-scrollbar {
	width: 6px;
	height: 6px;
}

.vs-account-content::-webkit-scrollbar-track,
.vs-orders-table-wrapper::-webkit-scrollbar-track {
	background: var(--vs-bg);
	border-radius: 3px;
}

.vs-account-content::-webkit-scrollbar-thumb,
.vs-orders-table-wrapper::-webkit-scrollbar-thumb {
	background: var(--vs-border);
	border-radius: 3px;
}

.vs-account-content::-webkit-scrollbar-thumb:hover,
.vs-orders-table-wrapper::-webkit-scrollbar-thumb:hover {
	background: var(--vs-text-muted);
}

/* Link Underline Animation */
.vs-view-all,
.vs-forgot-link {
	position: relative;
}

.vs-view-all::after,
.vs-forgot-link::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 0;
	height: 2px;
	background: currentColor;
	transition: width 0.3s ease;
}

.vs-view-all:hover::after,
.vs-forgot-link:hover::after {
	width: 100%;
}

/* Order Row Animation */
.vs-orders-table tbody tr {
	transition: var(--vs-transition);
}

.vs-orders-table tbody tr:hover {
	transform: scale(1.005);
}

/* Empty State Illustration */
.vs-empty-icon svg {
	animation: float 3s ease-in-out infinite;
}

@keyframes float {
	0%, 100% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(-10px);
	}
}

/* Focus Ring for Accessibility */
.vs-btn:focus-visible,
.vs-input:focus-visible,
.vs-nav-item a:focus-visible {
	outline: 3px solid rgba(255, 170, 1, 0.5);
	outline-offset: 2px;
}

/* Print Styles */
@media print {
	.vs-account-nav,
	.vs-avatar-edit,
	.vs-quick-actions,
	.vs-btn {
		display: none !important;
	}
	
	.vs-myaccount-container {
		display: block;
	}
	
	.vs-account-content {
		box-shadow: none;
		padding: 0;
	}
}

/* ========================================
   Toast Notifications
======================================== */

.vs-toast {
	position: fixed;
	top: 100px;
	right: 20px;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 16px 24px;
	background: var(--vs-white);
	border-radius: var(--vs-radius-sm);
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
	transform: translateX(120%);
	transition: transform 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
	z-index: 10000;
	font-size: 14px;
	font-weight: 600;
}

.vs-toast.is-visible {
	transform: translateX(0);
}

.vs-toast-success {
	border-left: 4px solid var(--vs-success);
}

.vs-toast-success svg {
	stroke: var(--vs-success);
}

.vs-toast-error {
	border-left: 4px solid var(--vs-error);
}

.vs-toast-error svg {
	stroke: var(--vs-error);
}

/* Input Error State */
.vs-input-error {
	display: block;
	font-size: 12px;
	color: var(--vs-error);
	margin-top: 6px;
	animation: fadeIn 0.3s ease;
}

/* ========================================
   Orders Page Styles
======================================== */

.vs-orders-list {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.vs-order-card {
	background: var(--vs-white);
	border: 1px solid var(--vs-border-light);
	border-radius: var(--vs-radius);
	overflow: hidden;
	transition: var(--vs-transition);
}

.vs-order-card:hover {
	border-color: var(--vs-border);
	box-shadow: var(--vs-shadow);
}

.vs-order-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 20px 24px;
	background: var(--vs-bg);
	border-bottom: 1px solid var(--vs-border-light);
}

.vs-order-info {
	display: flex;
	flex-wrap: wrap;
	gap: 24px;
}

.vs-order-info-item {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.vs-order-info-label {
	font-size: 12px;
	color: var(--vs-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.vs-order-info-value {
	font-size: 14px;
	font-weight: 600;
	color: var(--vs-text);
}

.vs-order-body {
	padding: 20px 24px;
}

.vs-order-products {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.vs-order-product {
	display: flex;
	align-items: center;
	gap: 16px;
}

.vs-order-product-image {
	width: 64px;
	height: 64px;
	border-radius: 8px;
	overflow: hidden;
	background: var(--vs-bg);
	flex-shrink: 0;
}

.vs-order-product-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.vs-order-product-details {
	flex: 1;
}

.vs-order-product-name {
	font-size: 14px;
	font-weight: 600;
	color: var(--vs-text);
	margin: 0 0 4px;
}

.vs-order-product-meta {
	font-size: 13px;
	color: var(--vs-text-muted);
}

.vs-order-product-price {
	font-size: 15px;
	font-weight: 700;
	color: var(--vs-secondary);
}

.vs-order-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 16px 24px;
	background: var(--vs-bg);
	border-top: 1px solid var(--vs-border-light);
}

.vs-order-total {
	font-size: 16px;
}

.vs-order-total-label {
	color: var(--vs-text-light);
	margin-right: 8px;
}

.vs-order-total-value {
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-weight: 800;
	color: var(--vs-secondary);
}

.vs-order-actions {
	display: flex;
	gap: 12px;
}

/* ========================================
   Address Page Styles
======================================== */

.vs-addresses {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
}

.vs-address-card {
	background: var(--vs-white);
	border: 2px solid var(--vs-border-light);
	border-radius: var(--vs-radius);
	padding: 24px;
	position: relative;
	transition: var(--vs-transition);
}

.vs-address-card:hover {
	border-color: var(--vs-primary);
}

.vs-address-card.is-default {
	border-color: var(--vs-primary);
	background: linear-gradient(135deg, #FFFBF0 0%, #FFF5E0 100%);
}

.vs-address-type {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
}

.vs-address-type-icon {
	width: 40px;
	height: 40px;
	background: var(--vs-bg);
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.vs-address-type-icon svg {
	stroke: var(--vs-text-light);
}

.vs-address-type-label {
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-size: 16px;
	font-weight: 800;
	color: var(--vs-secondary);
}

.vs-address-default-badge {
	position: absolute;
	top: 16px;
	right: 16px;
	background: var(--vs-primary);
	color: var(--vs-white);
	font-size: 10px;
	font-weight: 700;
	padding: 4px 10px;
	border-radius: 4px;
	text-transform: uppercase;
}

.vs-address-content {
	color: var(--vs-text-light);
	font-size: 14px;
	line-height: 1.8;
	margin-bottom: 20px;
}

.vs-address-content strong {
	color: var(--vs-text);
	font-weight: 600;
	display: block;
	margin-bottom: 4px;
}

.vs-address-actions {
	display: flex;
	gap: 12px;
}

.vs-address-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 16px;
	font-size: 13px;
	font-weight: 600;
	border-radius: 6px;
	transition: var(--vs-transition);
	cursor: pointer;
}

.vs-address-btn-edit {
	background: var(--vs-secondary);
	color: var(--vs-white);
	border: none;
}

.vs-address-btn-edit:hover {
	background: var(--vs-primary);
}

.vs-address-btn-delete {
	background: transparent;
	color: var(--vs-text-muted);
	border: 1px solid var(--vs-border);
}

.vs-address-btn-delete:hover {
	border-color: var(--vs-error);
	color: var(--vs-error);
}

.vs-add-address {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 200px;
	background: var(--vs-bg);
	border: 2px dashed var(--vs-border);
	border-radius: var(--vs-radius);
	cursor: pointer;
	transition: var(--vs-transition);
}

.vs-add-address:hover {
	border-color: var(--vs-primary);
	background: linear-gradient(135deg, #FFFBF0 0%, transparent 100%);
}

.vs-add-address-icon {
	width: 56px;
	height: 56px;
	background: var(--vs-white);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 12px;
	transition: var(--vs-transition);
}

.vs-add-address:hover .vs-add-address-icon {
	background: var(--vs-primary);
}

.vs-add-address-icon svg {
	stroke: var(--vs-text-muted);
	transition: var(--vs-transition);
}

.vs-add-address:hover .vs-add-address-icon svg {
	stroke: var(--vs-white);
}

.vs-add-address-text {
	font-size: 14px;
	font-weight: 600;
	color: var(--vs-text-muted);
}

/* ========================================
   Page Header
======================================== */

.vs-page-header {
	margin-bottom: 32px;
}

.vs-page-title {
	font-family: 'AvenirLTStd-Black', sans-serif;
	font-size: 28px;
	font-weight: 900;
	color: var(--vs-secondary);
	margin: 0 0 8px;
}

.vs-page-desc {
	font-size: 15px;
	color: var(--vs-text-muted);
	margin: 0;
}

/* Order More Items */
.vs-order-more {
	font-size: 13px;
	color: var(--vs-text-muted);
	margin: 8px 0 0;
	font-style: italic;
}

/* Pay Now Button */
.vs-btn-pay {
	background: var(--vs-primary) !important;
	color: var(--vs-white) !important;
}

.vs-btn-pay:hover {
	background: var(--vs-primary-hover) !important;
}

.vs-btn-outline {
	background: transparent !important;
	color: var(--vs-text) !important;
	border: 1px solid var(--vs-border) !important;
}

.vs-btn-outline:hover {
	border-color: var(--vs-primary) !important;
	color: var(--vs-primary) !important;
}

/* ========================================
   Pagination
======================================== */

.vs-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
	margin-top: 40px;
	padding-top: 32px;
	border-top: 1px solid var(--vs-border-light);
}

.vs-pagination-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 20px;
	font-size: 14px;
	font-weight: 600;
	color: var(--vs-text);
	background: var(--vs-white);
	border: 1px solid var(--vs-border);
	border-radius: var(--vs-radius-sm);
	transition: var(--vs-transition);
}

.vs-pagination-btn:hover {
	border-color: var(--vs-primary);
	color: var(--vs-primary);
}

.vs-pagination-info {
	font-size: 14px;
	color: var(--vs-text-muted);
}

/* ========================================
   Empty State
======================================== */

.vs-empty-state {
	text-align: center;
	padding: 80px 20px;
}

.vs-empty-state .vs-empty-icon {
	margin-bottom: 24px;
}

.vs-empty-state .vs-empty-icon svg {
	animation: float 3s ease-in-out infinite;
}

.vs-empty-state h3 {
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-size: 24px;
	font-weight: 800;
	color: var(--vs-secondary);
	margin: 0 0 12px;
}

.vs-empty-state p {
	font-size: 15px;
	color: var(--vs-text-light);
	margin: 0 0 32px;
	max-width: 400px;
	margin-left: auto;
	margin-right: auto;
}

.vs-empty-state .vs-btn {
	display: inline-flex;
	width: auto;
	padding: 0 36px;
}

/* ========================================
   Account Edit Form Styles
======================================== */

.vs-edit-form {
	max-width: 600px;
}

.vs-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

.vs-form-section {
	margin-bottom: 40px;
	padding-bottom: 40px;
	border-bottom: 1px solid var(--vs-border-light);
}

.vs-form-section:last-child {
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

.vs-form-section-title {
	font-family: 'AvenirLTStd-Heavy', sans-serif;
	font-size: 18px;
	font-weight: 800;
	color: var(--vs-secondary);
	margin: 0 0 24px;
	display: flex;
	align-items: center;
	gap: 10px;
}

.vs-form-section-title svg {
	stroke: var(--vs-primary);
}
/* 眼睛图标，点击切换密码显示隐藏 - WooCommerce 默认密码显示按钮 */
.show-password-input {
	position: absolute;
    right: 6px;
    top: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    line-height: 1;
    cursor: pointer;
    background: none;
    border: none;
    padding: 0;
    color: var(--vs-text-muted);
    transition: transform 0.2s ease;
}


/* 隐藏默认文字，只显示图标 */
.show-password-input::before {
	font-size: 20px;
}


/* 密码输入框容器相对定位 */
.woocommerce-form-row .password-input {
	position: relative;
}

/* 使用自定义眼睛图标替换默认样式 */
.show-password-input.display-password::before {
	content: "";
	background: url('../images/eye-close.svg') no-repeat center center;
    width: 20px;
    height: 20px;
}

.show-password-input::before {
	content: "";
	font-family: inherit;
	background: url('../images/eye.svg') no-repeat center center;
    width: 20px;
    height: 20px;
}

.woocommerce-form-login .show-password-input::before{
	display: none;
}

.show-password-input:hover::before {
	background: url('../images/eye-hover.svg') no-repeat center center;
}

.show-password-input.display-password:hover::before {
	background: url('../images/eye-close-hover.svg') no-repeat center center;
}

/* 密码强度指示器样式调整 */
.woocommerce-password-strength {
	margin-top: 8px;
	padding: 8px 12px;
	border-radius: 4px;
	font-size: 13px;
	font-weight: 500;
}

.woocommerce-password-strength.short {
	background: #fee2e2;
	color: #dc2626;
}

.woocommerce-password-strength.bad {
	background: #fef3c7;
	color: #d97706;
}

.woocommerce-password-strength.good {
	background: #d1fae5;
	color: #059669;
}

.woocommerce-password-strength.strong {
	background: #cffafe;
	color: #0891b2;
}

/* Responsive for new styles */
@media (max-width: 768px) {
	.vs-addresses {
		grid-template-columns: 1fr;
	}
	
	.vs-order-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 16px;
	}
	
	.vs-order-info {
		width: 100%;
	}
	
	.vs-order-footer {
		flex-direction: column;
		gap: 16px;
	}
	
	.vs-order-actions {
		width: 100%;
	}
	
	.vs-order-actions .vs-btn-small {
		flex: 1;
		text-align: center;
	}
	
	.vs-form-row {
		grid-template-columns: 1fr;
	}
	
	.vs-auth-page-title {
		font-size: 28px;
	}
	
	.vs-toast {
		left: 20px;
		right: 20px;
	}
}

