/* ================================================================
   ECLIPSE VAPE – Main Stylesheet
   Version: 1.0.0
   ================================================================ */

/* ----------------------------------------------------------------
   1. CSS CUSTOM PROPERTIES (DESIGN TOKENS)
   ---------------------------------------------------------------- */
:root {
	/* Colors */
	--ev-bg-deep:      #080c10;
	--ev-bg-base:      #0d1117;
	--ev-bg-card:      #111820;
	--ev-bg-card-alt:  #141d27;
	--ev-bg-elevated:  #1a2333;
	--ev-border:       rgba(0, 229, 255, 0.12);
	--ev-border-hover: rgba(0, 229, 255, 0.35);

	/* Accent (overridable from Customizer via dynamic CSS) */
	--ev-accent:       #00e5ff;
	--ev-accent-dim:   #00b8cc;
	--ev-accent-glow:  rgba(0, 229, 255, 0.18);
	--ev-accent-glow2: rgba(0, 229, 255, 0.08);

	/* Text */
	--ev-text-primary:   #f0f4f8;
	--ev-text-secondary: #8b9ab0;
	--ev-text-muted:     #4a5568;

	/* Status */
	--ev-success:  #00e676;
	--ev-warning:  #ffb300;
	--ev-error:    #ff5252;

	/* Typography */
	--ev-font-heading: 'Rajdhani', 'Inter', sans-serif;
	--ev-font-display: 'Orbitron', 'Rajdhani', sans-serif;
	--ev-font-body:    'Inter', system-ui, sans-serif;

	/* Spacing */
	--ev-section-padding: clamp(3rem, 6vw, 6rem);
	--ev-container-max:   1280px;
	--ev-container-pad:   clamp(1rem, 4vw, 2rem);

	/* Radius */
	--ev-radius-sm:  6px;
	--ev-radius-md:  12px;
	--ev-radius-lg:  20px;
	--ev-radius-xl:  32px;

	/* Transitions */
	--ev-transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
	--ev-transition-slow: 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ----------------------------------------------------------------
   2. RESET & BASE
   ---------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
	scroll-behavior: smooth;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body {
	background-color: var(--ev-bg-base);
	color: var(--ev-text-primary);
	font-family: var(--ev-font-body);
	font-size: 16px;
	line-height: 1.6;
	overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, textarea, select { font-family: inherit; }

/* Screen Reader / Accessibility */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}
.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* ----------------------------------------------------------------
   3. LAYOUT UTILITIES
   ---------------------------------------------------------------- */
.ev-container {
	max-width: var(--ev-container-max);
	margin-inline: auto;
	padding-inline: var(--ev-container-pad);
}

.ev-section {
	padding-block: var(--ev-section-padding);
}

.ev-section__header {
	text-align: center;
	margin-bottom: 3rem;
}

.ev-section__title {
	font-family: var(--ev-font-heading);
	font-size: clamp(1.6rem, 3vw, 2.5rem);
	font-weight: 700;
	letter-spacing: 0.08em;
	color: var(--ev-text-primary);
	text-transform: uppercase;
}

.ev-section__line {
	width: 60px;
	height: 3px;
	background: var(--ev-accent);
	margin: 0.75rem auto 0;
	border-radius: 2px;
	box-shadow: 0 0 12px var(--ev-accent);
}

.ev-section__footer {
	text-align: center;
	margin-top: 2.5rem;
}

.ev-accent { color: var(--ev-accent); }

/* ----------------------------------------------------------------
   4. BUTTONS
   ---------------------------------------------------------------- */
.ev-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 2rem;
	border-radius: var(--ev-radius-sm);
	font-family: var(--ev-font-heading);
	font-size: 0.9rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	transition: all var(--ev-transition);
	position: relative;
	overflow: hidden;
	white-space: nowrap;
}

.ev-btn--primary {
	background: var(--ev-accent);
	color: var(--ev-bg-deep);
}
.ev-btn--primary:hover {
	background: #fff;
	color: var(--ev-bg-deep);
	box-shadow: 0 0 30px rgba(255,255,255,0.3);
}

.ev-btn--outline {
	background: transparent;
	border: 1px solid rgba(0, 229, 255, 0.4);
	color: #fff;
}
.ev-btn--outline:hover {
	border-color: var(--ev-accent);
	background: rgba(0, 229, 255, 0.05);
	color: var(--ev-accent);
}

.ev-btn--sm {
	padding: 0.5rem 1.25rem;
	font-size: 0.8rem;
}

.ev-btn svg { flex-shrink: 0; }

/* ----------------------------------------------------------------
   5. HEADER
   ---------------------------------------------------------------- */
.ev-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: rgba(8, 12, 16, 0.85);
	backdrop-filter: blur(16px) saturate(180%);
	-webkit-backdrop-filter: blur(16px) saturate(180%);
	border-bottom: 1px solid var(--ev-border);
	transition: background var(--ev-transition), box-shadow var(--ev-transition);
}
/* Admin Bar Compatibility */
.admin-bar .ev-header {
	top: 32px;
}
@media screen and (max-width: 782px) {
	.admin-bar .ev-header {
		top: 46px;
	}
}
@media screen and (max-width: 600px) {
	.admin-bar .ev-header {
		position: absolute;
		top: 0;
	}
}
.ev-header.is-scrolled {
	background: rgba(8, 12, 16, 0.97);
	box-shadow: 0 4px 30px rgba(0, 0, 0, 0.5);
}
.ev-scroll-progress {
	position: absolute;
	top: 0;
	left: 0;
	width: 0%;
	height: 3px;
	background: linear-gradient(to right, var(--ev-accent-dim), var(--ev-accent));
	box-shadow: 0 0 10px var(--ev-accent);
	z-index: 1001;
	transition: width 0.1s linear;
}

.ev-header__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 2rem;
	height: 70px;
}

/* Logo */
.ev-header__logo .custom-logo { height: 40px; width: auto; }
.ev-logo-text {
	font-family: var(--ev-font-display);
	font-size: 1.6rem;
	font-weight: 900;
	color: var(--ev-accent);
	letter-spacing: 0.05em;
	text-shadow: 0 0 10px var(--ev-accent-glow), 0 0 20px var(--ev-accent-glow), 0 0 30px var(--ev-accent-glow);
	transition: text-shadow 0.3s ease;
}
.ev-logo-text:hover {
	text-shadow: 0 0 15px var(--ev-accent), 0 0 30px var(--ev-accent), 0 0 45px var(--ev-accent);
}

/* Nav */
.ev-header__nav { display: flex; align-items: center; justify-content: center; }
.ev-nav__menu {
	display: flex;
	align-items: center;
	gap: 0.25rem;
	list-style: none;
}
.ev-nav__menu > li > a {
	display: block;
	padding: 0.5rem 1rem;
	font-family: var(--ev-font-heading);
	font-size: 0.9rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--ev-text-secondary);
	border-radius: var(--ev-radius-sm);
	transition: color var(--ev-transition), background var(--ev-transition);
	position: relative;
}
.ev-nav__menu > li > a::after {
	content: '';
	position: absolute;
	bottom: 2px;
	left: 50%;
	transform: translateX(-50%);
	width: 0;
	height: 2px;
	background: var(--ev-accent);
	border-radius: 1px;
	transition: width var(--ev-transition);
}
.ev-nav__menu > li > a:hover,
.ev-nav__menu > li.current-menu-item > a {
	color: var(--ev-accent);
}
.ev-nav__menu > li > a:hover::after,
.ev-nav__menu > li.current-menu-item > a::after {
	width: 50%;
}

/* Dropdown */
.ev-nav__menu .sub-menu {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	min-width: 200px;
	background: var(--ev-bg-elevated);
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius-md);
	list-style: none;
	padding: 0.5rem;
	opacity: 0;
	pointer-events: none;
	transform: translateY(-8px);
	transition: all var(--ev-transition);
	box-shadow: 0 10px 40px rgba(0,0,0,0.5), 0 0 0 1px var(--ev-border);
}
.ev-nav__menu li:hover > .sub-menu {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}
.ev-nav__menu .sub-menu a {
	display: block;
	padding: 0.6rem 1rem;
	font-family: var(--ev-font-body);
	font-size: 0.85rem;
	color: var(--ev-text-secondary);
	border-radius: var(--ev-radius-sm);
	transition: color var(--ev-transition), background var(--ev-transition);
}
.ev-nav__menu .sub-menu a:hover {
	color: var(--ev-accent);
	background: var(--ev-accent-glow2);
}

/* Header Actions */
.ev-header__actions {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.ev-header__action-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--ev-radius-sm);
	color: var(--ev-text-secondary);
	transition: color var(--ev-transition), background var(--ev-transition);
	position: relative;
}
.ev-header__action-btn:hover { color: var(--ev-accent); background: var(--ev-accent-glow2); }

.ev-cart-count {
	position: absolute;
	top: 4px;
	right: 4px;
	min-width: 18px;
	height: 18px;
	background: var(--ev-accent);
	color: #000;
	border-radius: 999px;
	font-size: 0.65rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 3px;
	line-height: 1;
}

/* Search Bar */
.ev-search-bar {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background: var(--ev-bg-deep);
	border-bottom: 1px solid var(--ev-border);
	padding: 1rem 0;
	transform: translateY(-100%);
	opacity: 0;
	pointer-events: none;
	transition: all var(--ev-transition);
}
.ev-search-bar.is-open {
	transform: translateY(0);
	opacity: 1;
	pointer-events: auto;
}
.ev-search-bar.is-open { display: block; animation: evFadeInDown 0.3s ease forwards; }

/* 10. AJAX LIVE SEARCH RESULTS */
.ev-search-results {
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	max-width: 600px;
	background: var(--ev-bg-card);
	border: 1px solid var(--ev-border);
	border-radius: 0 0 var(--ev-radius-md) var(--ev-radius-md);
	box-shadow: 0 15px 50px rgba(0,0,0,0.6);
	z-index: 99;
	display: none;
	max-height: 400px;
	overflow-y: auto;
	backdrop-filter: blur(15px);
	-webkit-backdrop-filter: blur(15px);
}
.ev-search-results.is-visible { display: block; }

.ev-search-results__grid { padding: 0.5rem; }

.ev-search-item {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 0.75rem 1rem;
	border-bottom: 1px solid rgba(255,255,255,0.05);
	transition: background var(--ev-transition);
	text-decoration: none;
}
.ev-search-item:last-child { border-bottom: none; }
.ev-search-item:hover { background: rgba(0, 229, 255, 0.05); }

.ev-search-item__img {
	width: 48px;
	height: 48px;
	border-radius: var(--ev-radius-sm);
	overflow: hidden;
	background: var(--ev-bg-elevated);
	flex-shrink: 0;
}
.ev-search-item__img img { width: 100%; height: 100%; object-fit: cover; }

.ev-search-item__info { display: flex; flex-direction: column; gap: 0.15rem; }
.ev-search-item__title {
	color: var(--ev-text-primary);
	font-weight: 600;
	font-size: 0.9rem;
	font-family: var(--ev-font-heading);
}
.ev-search-item__price {
	color: var(--ev-accent);
	font-weight: 700;
	font-size: 0.85rem;
}

.ev-search-loading, .ev-search-no-results {
	padding: 1.5rem;
	text-align: center;
	color: var(--ev-text-muted);
	font-size: 0.9rem;
}
.ev-search-bar__input {
	flex: 1;
	background: var(--ev-bg-card);
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius-sm);
	color: var(--ev-text-primary);
	padding: 0.75rem 1rem;
	font-size: 1rem;
	outline: none;
	transition: border-color var(--ev-transition);
}
.ev-search-bar__input:focus { border-color: var(--ev-accent); }
.ev-search-bar__input::placeholder { color: var(--ev-text-muted); }
.ev-search-bar__submit {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	background: var(--ev-accent);
	color: #000;
	border-radius: var(--ev-radius-sm);
	transition: background var(--ev-transition);
}
.ev-search-bar__submit:hover { background: var(--ev-accent-dim); }

/* Hamburger */
.ev-hamburger {
	display: none;
	flex-direction: column;
	gap: 5px;
	padding: 8px;
}
.ev-hamburger span {
	display: block;
	width: 22px;
	height: 2px;
	background: var(--ev-text-primary);
	border-radius: 2px;
	transition: all var(--ev-transition);
}
.ev-hamburger.is-active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.ev-hamburger.is-active span:nth-child(2) { opacity: 0; }
.ev-hamburger.is-active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile Nav */
.ev-mobile-nav {
	position: fixed;
	top: 70px;
	left: 0;
	right: 0;
	bottom: 0;
	background: var(--ev-bg-deep);
	z-index: 999;
	transform: translateX(-100%);
	transition: transform var(--ev-transition-slow);
	overflow-y: auto;
}
.ev-mobile-nav.is-open { transform: translateX(0); }
.ev-mobile-nav__inner { padding: 2rem; }
.ev-mobile-nav__menu { list-style: none; }
.ev-mobile-nav__menu > li { border-bottom: 1px solid var(--ev-border); }
.ev-mobile-nav__menu > li > a {
	display: block;
	padding: 1rem 0;
	font-family: var(--ev-font-heading);
	font-size: 1.1rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--ev-text-primary);
	transition: color var(--ev-transition);
}
.ev-mobile-nav__menu > li > a:hover { color: var(--ev-accent); }
.ev-mobile-nav__actions { margin-top: 2rem; }
.ev-mobile-overlay {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.6);
	z-index: 998;
}
.ev-mobile-overlay.is-visible { display: block; }

/* ----------------------------------------------------------------
   6. HERO
   ---------------------------------------------------------------- */
.ev-hero {
	position: relative;
	min-height: 90vh;
	display: flex;
	align-items: center;
	padding-top: 70px;
	overflow: hidden;
}
.ev-hero__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: right -100px center;
	background-repeat: no-repeat;
	transform: scale(1.03);
	transition: transform 8s ease;
}
.ev-hero:hover .ev-hero__bg { transform: scale(1); }
.ev-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to right,
		rgba(8,12,16,0.8) 0%,
		rgba(8,12,16,0.4) 40%,
		transparent 70%
	);
}
.ev-hero .ev-container {
	max-width: 100%;
	margin-left: 0;
	padding-left: 5%;
}
.ev-hero__content {
	position: relative;
	z-index: 1;
}
.ev-hero__text {
	max-width: 720px;
	text-align: left;
}
.ev-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.5rem 1rem;
	background: rgba(var(--ev-bg-alt-rgb), 0.5);
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: 100px;
	color: var(--ev-accent);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	margin-bottom: 2rem;
	text-transform: uppercase;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}
.ev-hero__badge span {
	width: 6px;
	height: 6px;
	background: var(--ev-accent);
	border-radius: 50%;
	box-shadow: 0 0 10px var(--ev-accent);
}
.ev-hero__heading {
	font-family: var(--ev-font-display);
	font-size: clamp(3rem, 8vw, 6rem);
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--ev-text-primary);
	margin-bottom: 1.5rem;
	text-shadow: 0 4px 30px rgba(0,0,0,0.8);
}
.ev-hero__heading .ev-accent {
	text-shadow: 0 0 30px var(--ev-accent), 0 0 60px var(--ev-accent-glow);
}
.ev-hero__subheading {
	font-size: 1.15rem;
	color: rgba(255,255,255,0.7);
	margin-bottom: 3rem;
	line-height: 1.6;
	max-width: 580px;
}
.ev-hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: flex-start; }

.ev-hero__scroll-hint {
	position: absolute;
	bottom: 2rem;
	left: 50%;
	transform: translateX(-50%);
}
.ev-hero__scroll-hint span {
	display: block;
	width: 2px;
	height: 40px;
	background: linear-gradient(to bottom, transparent, var(--ev-accent));
	margin: 0 auto;
	animation: scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
	0%, 100% { opacity: 0.3; height: 30px; }
	50%       { opacity: 1;   height: 50px; }
}

/* ----------------------------------------------------------------
   TRUST BAR (STATIC)
   ---------------------------------------------------------------- */
.ev-trust-bar {
	background: var(--ev-bg-card);
	border-top: 1px solid var(--ev-border);
	border-bottom: 1px solid var(--ev-border);
	padding: 1.5rem 0;
	position: relative;
	z-index: 10;
}
.ev-trust-bar__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 2rem;
	flex-wrap: wrap;
}
.ev-trust-item {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	color: var(--ev-text-primary);
	font-family: var(--ev-font-heading);
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	transition: transform 0.3s ease;
}
.ev-trust-item:hover {
	transform: translateY(-2px);
}
.ev-trust-item svg {
	color: var(--ev-accent);
	filter: drop-shadow(0 0 5px var(--ev-accent-glow));
}
@media screen and (max-width: 768px) {
	.ev-trust-bar__inner {
		justify-content: center;
		gap: 1.5rem;
	}
}
/* ----------------------------------------------------------------
   7. PRODUCT GRID & CARDS
   ---------------------------------------------------------------- */
.ev-product-grid {
	display: grid;
	gap: 1.5rem;
}
.ev-product-grid--4 { grid-template-columns: repeat(4, 1fr); }
.ev-product-grid--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 991px) {
	.ev-product-grid--4, .ev-product-grid--3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 576px) {
	.ev-product-grid--4, .ev-product-grid--3 { grid-template-columns: 1fr; }
}

.ev-product-card {
	background: var(--ev-bg-card);
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius-md);
	overflow: hidden;
	transition: border-color var(--ev-transition), transform var(--ev-transition), box-shadow var(--ev-transition);
}
.ev-product-card:hover {
	border-color: var(--ev-border-hover);
	transform: translateY(-6px);
	box-shadow: 0 20px 50px rgba(0,0,0,0.4), 0 0 30px var(--ev-accent-glow2);
}
.ev-product-card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(
		600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
		var(--ev-accent-glow2),
		transparent 40%
	);
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.5s var(--ev-transition);
	z-index: 0;
}
.ev-product-card:hover::before { opacity: 1; }

.ev-product-card__img-wrap {
	display: block;
	position: relative;
	overflow: hidden;
	aspect-ratio: 1/1;
	background: var(--ev-bg-card-alt);
}
.ev-product-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--ev-transition-slow);
}
.ev-product-card:hover .ev-product-card__img { transform: scale(1.06); }

.ev-product-card__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 229, 255, 0.08);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity var(--ev-transition);
}
.ev-product-card:hover .ev-product-card__overlay { opacity: 1; }
.ev-product-card__quick-view {
	background: rgba(0,0,0,0.8);
	color: var(--ev-accent);
	border: 1px solid var(--ev-accent);
	padding: 0.5rem 1.25rem;
	border-radius: var(--ev-radius-sm);
	font-family: var(--ev-font-heading);
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	transition: background var(--ev-transition);
}
.ev-product-card__quick-view:hover { background: var(--ev-accent); color: #000; }

/* Badges */
.ev-badge {
	position: absolute;
	top: 10px;
	left: 10px;
	font-family: var(--ev-font-heading);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: 4px;
	z-index: 1;
}
.ev-badge--sale      { background: var(--ev-error); color: #fff; }
.ev-badge--featured  { background: var(--ev-accent); color: #000; }
.ev-badge--bestseller { background: var(--ev-warning); color: #000; }
.ev-badge--new       { background: var(--ev-success); color: #000; }

.ev-product-card__body {
	padding: 1rem 1.25rem 1.25rem;
}
.ev-product-card__meta { margin-bottom: 0.75rem; }
.ev-product-card__title {
	font-family: var(--ev-font-heading);
	font-size: 0.95rem;
	font-weight: 600;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: var(--ev-text-primary);
	line-height: 1.3;
}
.ev-product-card__title a:hover { color: var(--ev-accent); }
.ev-product-card__rating { margin-top: 0.35rem; display: flex; align-items: center; gap: 0.4rem; }
.ev-rating-count { font-size: 0.8rem; color: var(--ev-warning); font-weight: 600; }

.ev-product-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
}
.ev-product-card__price {
	font-family: var(--ev-font-heading);
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--ev-accent);
}
.ev-product-card__footer .add_to_cart_button {
	background: var(--ev-accent) !important;
	color: #000 !important;
	padding: 0.5rem 1rem !important;
	border-radius: var(--ev-radius-sm) !important;
	font-family: var(--ev-font-heading) !important;
	font-size: 0.75rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.05em !important;
	text-transform: uppercase !important;
	box-shadow: 0 0 10px var(--ev-accent-glow) !important;
	border: none !important;
	text-decoration: none !important;
	transition: all 0.3s ease !important;
}
.ev-product-card__footer .add_to_cart_button:hover {
	background: #fff !important;
	box-shadow: 0 0 20px rgba(255,255,255,0.4) !important;
	transform: translateY(-2px);
}
.ev-product-card__footer .add_to_cart_button.loading {
	opacity: 0.7;
}
.ev-product-card__footer .add_to_cart_button.added {
	background: #28a745 !important;
	box-shadow: 0 0 10px #28a745 !important;
	color: #fff !important;
}

/* ----------------------------------------------------------------
   8. CATEGORIES
   ---------------------------------------------------------------- */
.ev-categories__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1.5rem;
}
.ev-category-card {
	position: relative;
	display: block;
	border-radius: var(--ev-radius-md);
	overflow: hidden;
	aspect-ratio: 3/2;
	transition: transform var(--ev-transition), box-shadow var(--ev-transition);
}
.ev-category-card:hover { transform: translateY(-5px); box-shadow: 0 20px 50px rgba(0,0,0,0.5); }
.ev-category-card__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transition: transform var(--ev-transition-slow);
}
.ev-category-card:hover .ev-category-card__bg { transform: scale(1.06); }
.ev-category-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.2) 60%, transparent 100%);
	transition: background var(--ev-transition);
}
.ev-category-card:hover .ev-category-card__overlay { background: linear-gradient(to top, rgba(0,229,255,0.25) 0%, rgba(0,0,0,0.3) 60%, transparent 100%); }
.ev-category-card__content {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 1.5rem;
}
.ev-category-card__name {
	font-family: var(--ev-font-heading);
	font-size: 1.3rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #fff;
}
.ev-category-card__count { font-size: 0.8rem; color: var(--ev-accent); font-weight: 600; }

/* ----------------------------------------------------------------
   9. FEATURES SECTION
   ---------------------------------------------------------------- */
.ev-features { background: var(--ev-bg-deep); }
.ev-features__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 2rem;
}
.ev-feature-card {
	text-align: center;
	padding: 2rem 1.5rem;
	background: var(--ev-bg-card);
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius-md);
	transition: border-color var(--ev-transition), transform var(--ev-transition);
}
.ev-feature-card:hover { border-color: var(--ev-border-hover); transform: translateY(-4px); }
.ev-feature-card__icon {
	width: 64px;
	height: 64px;
	background: var(--ev-accent-glow);
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1.25rem;
	color: var(--ev-accent);
	transition: background var(--ev-transition), box-shadow var(--ev-transition);
}
.ev-feature-card:hover .ev-feature-card__icon {
	background: var(--ev-accent-glow);
	box-shadow: 0 0 20px var(--ev-accent-glow);
}
.ev-feature-card h4 {
	font-family: var(--ev-font-heading);
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin-bottom: 0.5rem;
	color: var(--ev-text-primary);
}
.ev-feature-card p { font-size: 0.875rem; color: var(--ev-text-secondary); line-height: 1.6; }

/* ----------------------------------------------------------------
   10. TESTIMONIALS
   ---------------------------------------------------------------- */
.ev-testimonials { background: var(--ev-bg-base); }
.ev-testimonials__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1.5rem;
}
.ev-testimonial-card {
	background: var(--ev-bg-card);
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius-md);
	padding: 1.75rem;
	transition: border-color var(--ev-transition);
}
.ev-testimonial-card:hover { border-color: var(--ev-border-hover); }
.ev-testimonial-card__stars { color: var(--ev-warning); font-size: 1rem; margin-bottom: 0.75rem; letter-spacing: 2px; }
.ev-testimonial-card__text {
	font-size: 0.9rem;
	line-height: 1.75;
	color: var(--ev-text-secondary);
	margin-bottom: 1.25rem;
	font-style: italic;
}
.ev-testimonial-card__author { display: flex; flex-direction: column; gap: 0.2rem; }
.ev-testimonial-card__name { font-weight: 600; font-size: 0.9rem; color: var(--ev-text-primary); }
.ev-testimonial-card__label { font-size: 0.75rem; color: var(--ev-accent); }

/* ----------------------------------------------------------------
   11. NEWSLETTER
   ---------------------------------------------------------------- */
.ev-newsletter {
	background: linear-gradient(135deg, rgba(0, 229, 255, 0.06), rgba(0, 0, 0, 0));
	border-top: 1px solid var(--ev-border);
	border-bottom: 1px solid var(--ev-border);
}
.ev-newsletter__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	flex-wrap: wrap;
}
.ev-newsletter__text h2 {
	font-family: var(--ev-font-heading);
	font-size: clamp(1.3rem, 2.5vw, 2rem);
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--ev-text-primary);
	margin-bottom: 0.4rem;
}
.ev-newsletter__text p { color: var(--ev-text-secondary); font-size: 0.9rem; }
.ev-newsletter__form {
	display: flex;
	gap: 0.75rem;
	flex: 1;
	min-width: 300px;
	max-width: 520px;
}
.ev-newsletter__form input[type="email"] {
	flex: 1;
	padding: 0.75rem 1.25rem;
	background: var(--ev-bg-card);
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius-sm);
	color: var(--ev-text-primary);
	font-size: 0.9rem;
	outline: none;
	transition: border-color var(--ev-transition);
}
.ev-newsletter__form input::placeholder { color: var(--ev-text-muted); }
.ev-newsletter__form input:focus { border-color: var(--ev-accent); }

/* ----------------------------------------------------------------
   12. FOOTER
   ---------------------------------------------------------------- */
.ev-footer {
	background: var(--ev-bg-deep);
	border-top: 1px solid var(--ev-border);
	padding: 2rem 0 0.5rem;
}

.ev-footer__unified-content {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: 2rem;
	align-items: start;
}

.ev-footer__title {
	font-family: var(--ev-font-heading);
	font-size: 1.8rem;
	font-weight: 800;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: #fff;
	margin: 0 0 1rem;
	background: linear-gradient(to right, #fff, var(--ev-accent));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.ev-footer__description {
	color: var(--ev-text-muted);
	font-size: 0.95rem;
	line-height: 1.7;
	max-width: 320px;
}

.ev-footer__menu-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.ev-footer__nav-columns {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}

@media (max-width: 576px) {
	.ev-footer__nav-columns {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
}

.ev-footer__menu-list li a {
	color: var(--ev-text-secondary);
	font-size: 0.9rem;
	transition: all 0.3s;
	text-decoration: none;
	display: inline-block;
}

.ev-footer__menu-list li a:hover {
	color: var(--ev-accent);
	transform: translateX(5px);
}

.ev-footer__copyright-block {
	text-align: right;
	grid-column: 1 / -1;
	border-top: 1px solid var(--ev-border);
	padding-top: 1rem;
	margin-top: 1rem;
	font-size: 0.85rem;
	color: var(--ev-text-muted);
}

@media (max-width: 991px) {
	.ev-footer__unified-content {
		grid-template-columns: 1fr;
		gap: 3rem;
		text-align: center;
	}
	.ev-footer__description {
		margin-left: auto;
		margin-right: auto;
	}
	.ev-footer__copyright-block {
		text-align: center;
	}
}

/* ----------------------------------------------------------------
   13. BREADCRUMB
   ---------------------------------------------------------------- */
.woocommerce-breadcrumb {
	background: var(--ev-bg-deep);
	border-bottom: 1px solid var(--ev-border);
	padding: 0.75rem 0;
	font-size: 0.82rem;
	color: var(--ev-text-muted);
}
.woocommerce-breadcrumb .ev-container { /* already wrapped */ }
.woocommerce-breadcrumb a { color: var(--ev-text-muted); transition: color var(--ev-transition); }
.woocommerce-breadcrumb a:hover { color: var(--ev-accent); }
.woocommerce-breadcrumb span:last-child { color: var(--ev-accent); }

/* ----------------------------------------------------------------
   14. AGE GATE
   ---------------------------------------------------------------- */
.ev-age-gate {
	position: fixed;
	inset: 0;
	z-index: 9999;
	background: rgba(0, 0, 0, 0.95);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
}
.ev-age-gate__card {
	background: var(--ev-bg-card);
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius-xl);
	padding: 3rem 2.5rem;
	text-align: center;
	max-width: 480px;
	width: 100%;
	box-shadow: 0 0 80px rgba(0, 229, 255, 0.15);
}
.ev-age-gate__logo { font-family: var(--ev-font-display); font-size: 2rem; font-weight: 900; color: var(--ev-accent); margin-bottom: 1.5rem; text-shadow: 0 0 20px var(--ev-accent); }
.ev-age-gate__title { font-family: var(--ev-font-heading); font-size: 1.5rem; font-weight: 700; color: var(--ev-text-primary); margin-bottom: 0.5rem; }
.ev-age-gate__text { color: var(--ev-text-secondary); font-size: 0.9rem; margin-bottom: 2rem; line-height: 1.6; }
.ev-age-gate__actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.ev-age-gate__deny { font-family: var(--ev-font-heading); font-size: 0.85rem; color: var(--ev-text-muted); cursor: pointer; text-decoration: underline; margin-top: 1rem; display: block; }
.ev-age-gate__deny:hover { color: var(--ev-error); }

/* ----------------------------------------------------------------
   15. GENERAL PAGE & POSTS
   ---------------------------------------------------------------- */
/* ----------------------------------------------------------------
   15. WOOCOMMERCE - SHOP & SINGLE PRODUCT
   ---------------------------------------------------------------- */
.ev-is-shop .ev-main { padding-bottom: 5rem; }

/* Single Product Layout */
.single-product div.product {
	display: flex;
	flex-wrap: wrap;
	gap: 3rem;
	align-items: flex-start;
	margin-top: 2rem;
}

.single-product .woocommerce-product-gallery {
	flex: 1 1 500px;
	border-radius: var(--ev-radius-lg);
	overflow: hidden;
	border: 1px solid var(--ev-border);
}

.single-product .summary {
	flex: 1 1 400px;
	background: var(--ev-bg-card);
	border: 1px solid var(--ev-border);
	padding: 2.5rem;
	border-radius: var(--ev-radius-xl);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
	box-shadow: 0 10px 40px rgba(0,0,0,0.3);
}

/* Single Product Elements */
.single-product .product_title {
	font-family: var(--ev-font-heading);
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--ev-text-primary);
	margin-bottom: 1rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.single-product .price {
	font-size: 1.8rem;
	font-weight: 700;
	color: var(--ev-accent);
	margin-bottom: 1.5rem;
	display: block;
}

.single-product .woocommerce-product-details__short-description {
	color: var(--ev-text-secondary);
	line-height: 1.7;
	margin-bottom: 2rem;
	font-size: 1rem;
}

.single-product .cart {
	display: flex;
	gap: 1rem;
	align-items: center;
	margin-top: 2rem;
	margin-bottom: 2rem;
	padding: 1.5rem 0;
	border-top: 1px solid var(--ev-border);
	border-bottom: 1px solid var(--ev-border);
}

.single-product .quantity input {
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid var(--ev-border);
	color: var(--ev-text-primary);
	padding: 0.75rem;
	border-radius: var(--ev-radius-sm);
	font-family: var(--ev-font-heading);
	width: 80px;
}

.single-product .single_add_to_cart_button {
	background: var(--ev-gradient-accent) !important;
	color: white !important;
	padding: 1rem 2rem !important;
	border-radius: var(--ev-radius-md) !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.1em !important;
	transition: var(--ev-transition) !important;
	box-shadow: 0 0 20px rgba(0, 229, 255, 0.2);
}

.single-product .single_add_to_cart_button:hover {
	transform: translateY(-3px);
	box-shadow: 0 0 30px rgba(0, 229, 255, 0.4);
}

.single-product .product_meta {
	font-size: 0.85rem;
	color: var(--ev-text-muted);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.single-product .product_meta span { color: var(--ev-text-secondary); font-weight: 600; }

/* Tabs & Data */
.single-product .woocommerce-tabs {
	width: 100%;
	margin-top: 4rem;
}

.woocommerce-tabs ul.tabs {
	display: flex;
	gap: 1rem;
	border-bottom: 1px solid var(--ev-border);
	padding-left: 0;
	margin-bottom: 2rem;
	list-style: none;
}

.woocommerce-tabs ul.tabs li {
	padding: 0.75rem 1.5rem;
	background: rgba(255,255,255,0.03);
	border-radius: var(--ev-radius-md) var(--ev-radius-md) 0 0;
	border: 1px solid var(--ev-border);
	border-bottom: none;
	cursor: pointer;
	transition: var(--ev-transition);
}

.woocommerce-tabs ul.tabs li.active {
	background: var(--ev-accent);
	color: white;
}

.woocommerce-tabs .woocommerce-Tabs-panel {
	color: var(--ev-text-secondary);
	line-height: 1.8;
	padding: 1rem 0;
}

@media (max-width: 768px) {
	.single-product div.product { flex-direction: column; }
	.single-product .woocommerce-product-gallery { width: 100%; flex: none; }
	.single-product .summary { width: 100%; flex: none; padding: 1.5rem; }
}

.ev-no-products { color: var(--ev-text-muted); text-align: center; padding: 3rem 0; font-style: italic; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ----------------------------------------------------------------
   19. WOOCOMMERCE MY ACCOUNT DASHBOARD
   ---------------------------------------------------------------- */
.woocommerce-account .ev-page-header {
	display: none !important;
}

.woocommerce-account .woocommerce {
	display: flex !important;
	flex-direction: column !important;
	gap: 1.5rem !important;
	padding: 0 0 4rem 0 !important;
	margin-top: -4rem !important;
}

.woocommerce-account .ev-main {
	padding-top: 0 !important;
}

/* My Account Navigation (Now forced Horizontal) */
.woocommerce-MyAccount-navigation {
	width: 100% !important;
	float: none !important;
	margin: 0 0 1.5rem 0 !important;
	background: var(--ev-bg-card);
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius-lg);
	overflow: hidden;
	box-shadow: 0 10px 30px rgba(0,0,0,0.3);
}

.woocommerce-MyAccount-navigation ul {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	width: 100% !important;
}

.woocommerce-MyAccount-navigation ul li {
	flex: 1 !important;
	min-width: 0 !important;
	border-right: 1px solid var(--ev-border) !important;
	border-bottom: none !important;
	margin: 0 !important;
}

.woocommerce-MyAccount-navigation ul li:last-child {
	border-right: none !important;
}

.woocommerce-MyAccount-navigation ul li a {
	display: block;
	padding: 1.5rem 0.5rem;
	text-align: center;
	color: var(--ev-text-secondary);
	font-family: var(--ev-font-heading);
	font-size: clamp(0.65rem, 1.5vw, 0.8rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	transition: all 0.3s ease;
	position: relative;
	white-space: nowrap;
}

.woocommerce-MyAccount-navigation ul li a::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 3px;
	background: var(--ev-accent);
	opacity: 0;
	transition: opacity 0.3s ease;
}

.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li a:hover {
	color: #fff;
	background: rgba(255,255,255,0.03);
}

.woocommerce-MyAccount-navigation ul li.is-active a::after {
	opacity: 1;
	box-shadow: 0 0 10px var(--ev-accent-glow);
}

/* My Account Content Area */
.woocommerce-MyAccount-content {
	width: 100% !important;
	margin: 0 !important;
	background: rgba(255,255,255,0.02);
	border: 1px solid var(--ev-border);
	padding: 3rem;
	border-radius: var(--ev-radius-lg);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
	min-height: 400px;
}

.woocommerce-MyAccount-content p {
	color: var(--ev-text-secondary);
	line-height: 1.8;
	margin-bottom: 1.5rem;
}

.woocommerce-MyAccount-content mark {
	background: var(--ev-accent);
	color: #000;
	padding: 0 4px;
	border-radius: 2px;
}

/* Force Account Details Layout - Side-by-Side */
form.woocommerce-EditAccountForm,
.woocommerce-edit-account form.edit-account {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	gap: 0.5rem 4rem !important;
	align-items: start !important;
}

/* Column 1: Personal Information */
form.woocommerce-EditAccountForm p.form-row[id*="first_name"],
form.woocommerce-EditAccountForm p.form-row[id*="last_name"],
form.woocommerce-EditAccountForm p.form-row[id*="display_name"],
form.woocommerce-EditAccountForm p.form-row[id*="email"] {
	grid-column: 1 !important;
	width: 100% !important;
	margin: 0 0 0.5rem 0 !important;
}

/* Column 2: Password Change Section */
form.woocommerce-EditAccountForm fieldset {
	grid-column: 2 !important;
	grid-row: 1 / span 5 !important; /* Adjust span as needed */
	width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
	border: none !important;
}

form.woocommerce-EditAccountForm fieldset legend {
	display: block !important;
	padding: 0 0 1.5rem 0 !important;
	font-family: var(--ev-font-heading);
	font-size: 1.1rem !important;
	color: var(--ev-accent) !important;
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

form.woocommerce-EditAccountForm fieldset p.form-row {
	width: 100% !important;
	margin-bottom: 1rem !important;
}

/* Global Dashboard Field Unification */
.woocommerce-MyAccount-content input,
.woocommerce-MyAccount-content select,
.woocommerce-MyAccount-content textarea,
.woocommerce-MyAccount-content .form-row,
.woocommerce-MyAccount-content [class*="form"] input,
.woocommerce-MyAccount-content [class*="form"] select,
.woocommerce-MyAccount-content [class*="form"] textarea {
	max-width: 400px !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

/* Ensure descriptions also respect this width */
.woocommerce-MyAccount-content span.description {
	max-width: 400px !important;
	width: 100% !important;
	font-size: 0.72rem !important;
	line-height: 1.4 !important;
	margin-top: 0.4rem !important;
	color: var(--ev-text-muted) !important;
	display: block !important;
	white-space: normal !important;
}

/* FINAL CHECKOUT BUTTON VISIBILITY FIX */
.woocommerce-checkout #place_order, 
.woocommerce-checkout #place_order_fix,
.woocommerce-checkout .ev-checkout-failsafe-submit button,
.woocommerce-checkout button[name="woocommerce_checkout_place_order"],
.wc-block-components-checkout-place-order-button {
    background: #00e5ff !important;
    color: #000000 !important;
    padding: 14px 32px !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    display: inline-block !important;
    width: auto !important;
    min-width: 220px !important;
    min-height: unset !important;
    visibility: visible !important;
    opacity: 1 !important;
    border: none !important;
    border-radius: var(--ev-radius-sm) !important;
    box-shadow: 0 0 20px rgba(0, 229, 255, 0.5) !important;
    margin: 20px 0 !important;
    cursor: pointer !important;
    z-index: 99 !important;
    text-align: center !important;
    line-height: 1.2 !important;
}

.woocommerce-checkout #place_order:hover,
.woocommerce-checkout #place_order_fix:hover {
    background: #ffffff !important;
    box-shadow: 0 0 70px #00e5ff !important;
    transform: translateY(-2px);
}



.woocommerce-edit-account form.edit-account .form-row {
	max-width: 400px !important;
}

.woocommerce-MyAccount-content .form-row {
	margin-bottom: 0.75rem !important;
}

.woocommerce-edit-account form fieldset p.form-row {
	margin-bottom: 1rem !important;
}

/* Dashboard Greeting */
.woocommerce-MyAccount-content .woocommerce-MyAccount-content__greeting {
	font-size: 1.5rem;
	margin-bottom: 2rem;
	color: #fff;
	font-family: var(--ev-font-heading);
}

/* Tables in Account (Orders, Addresses) */
.woocommerce-MyAccount-content table.shop_table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	border: 1px solid var(--ev-border);
	border-radius: var(--ev-radius-md);
	overflow: hidden;
	margin-bottom: 2rem;
}

.woocommerce-MyAccount-content table.shop_table thead th {
	background: rgba(255,255,255,0.05);
	padding: 1.25rem 1rem;
	color: var(--ev-accent);
	text-transform: uppercase;
	font-size: 0.75rem;
	letter-spacing: 0.1em;
	text-align: left;
	border-bottom: 1px solid var(--ev-border);
}

.woocommerce-MyAccount-content table.shop_table tbody td {
	padding: 1.25rem 1rem;
	border-bottom: 1px solid var(--ev-border);
	color: var(--ev-text-primary);
	font-size: 0.9rem;
}

.woocommerce-MyAccount-content table.shop_table tbody tr:last-child td {
	border-bottom: none;
}

/* Buttons in Content */
.woocommerce-MyAccount-content .ev-btn, 
.woocommerce-MyAccount-content .button {
	display: inline-flex;
	align-items: center;
	padding: 0.75rem 1.5rem;
	background: var(--ev-accent);
	color: #000 !important;
	border-radius: var(--ev-radius-sm);
	font-family: var(--ev-font-heading);
	font-size: 0.8rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	transition: all 0.3s ease;
	border: none;
}

.woocommerce-MyAccount-content .ev-btn:hover,
.woocommerce-MyAccount-content .button:hover {
	transform: translateY(-2px);
	box-shadow: 0 5px 15px var(--ev-accent-glow);
	background: #fff;
}

/* Notices & Messaging */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
	background: var(--ev-bg-card);
	border: 1px solid var(--ev-accent);
	border-left-width: 4px;
	padding: 1.25rem 2rem;
	color: #fff;
	border-radius: var(--ev-radius-sm);
	margin-bottom: 2rem;
	display: flex;
	align-items: center;
	gap: 1rem;
	box-shadow: 0 0 20px rgba(0,255,249,0.1);
}

/* Responsive Dashboard */
@media (max-width: 991px) {
	.woocommerce-account .woocommerce {
		flex-direction: column;
	}
	.woocommerce-MyAccount-navigation {
		width: 100%;
		margin-bottom: 2rem;
	}
	.woocommerce-MyAccount-content {
		width: 100%;
		padding: 2rem;
	}
}

/* ----------------------------------------------------------------
   20. RESPONSIVE
   ---------------------------------------------------------------- */
@media (max-width: 1024px) {
	.ev-footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}

@media (max-width: 768px) {
	.ev-header__nav { display: none; }
	.ev-hamburger { display: flex; }
	.ev-hero { min-height: 80vh; }
	.ev-hero__heading { font-size: clamp(2rem, 8vw, 3rem); }
	.ev-newsletter__inner { flex-direction: column; }
	.ev-newsletter__form { max-width: 100%; min-width: 0; width: 100%; }
	.ev-footer__grid { grid-template-columns: 1fr; gap: 1.5rem; }
	.ev-footer__bottom-inner { flex-direction: column; text-align: center; }
	.ev-product-grid--4 { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
}

@media (max-width: 480px) {
	.ev-hero { min-height: 70vh; }
	.ev-hero__actions { flex-direction: column; }
	.ev-hero__actions .ev-btn { text-align: center; justify-content: center; }
	.ev-categories__grid { grid-template-columns: 1fr; }
	.ev-features__grid { grid-template-columns: 1fr 1fr; }
}

/* ----------------------------------------------------------------
   18. DYNAMIC VAPE SMOKE BACKGROUND
   ---------------------------------------------------------------- */
.ev-vape-bg {
	position: fixed;
	top: -5%;
	left: -5%;
	width: 110vw;
	height: 110vh;
	z-index: -10;
	overflow: hidden;
	background-color: var(--ev-bg-deep); /* Base dark color */
	background-image: url('../images/vape-smoke-bg.png');
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	pointer-events: none;
	opacity: 0.6; /* Very subtle and delicate ('zerif') */
	animation: ev-drift-bg 40s infinite alternate linear;
}

@keyframes ev-drift-bg {
	0% { transform: scale(1) translate(0, 0); }
	50% { transform: scale(1.05) translate(-2%, 2%); }
	100% { transform: scale(1.02) translate(1%, -1%); }
}

/* The fine lines pattern (subtle overlay mesh) */
.ev-vape-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(
		45deg,
		rgba(255, 255, 255, 0.015) 0px,
		rgba(255, 255, 255, 0.015) 1px,
		transparent 1px,
		transparent 15px
	);
	pointer-events: none;
	z-index: 1;
}
