/* ============================================================================
   Evolve AI Vape Match — front-end wizard
   Dark glassmorphism with neon-lime accents. Mobile-first.
   Inherits Evolve theme tokens (--evolve-*) when the Evolve Child theme is
   loaded; falls back to its own defaults on any other theme.
   ========================================================================= */
.evolve-aivm {
	--evolve-aivm-bg:       var(--evolve-bg,       #050505);
	--evolve-aivm-card:     var(--evolve-card,     #111111);
	--evolve-aivm-card-2:   var(--evolve-card-2,   #161616);
	--evolve-aivm-border:   var(--evolve-border,   #1E1E1E);
	--evolve-aivm-text:     var(--evolve-text,     #FFFFFF);
	--evolve-aivm-dim:      var(--evolve-text-dim, #B3B3B3);
	--evolve-aivm-mute:     var(--evolve-text-mute,#6E6E6E);
	--evolve-aivm-accent:   var(--evolve-accent,   #B7FF00);
	--evolve-aivm-accent-2: var(--evolve-accent-2, #7CFF4F);
	--evolve-aivm-error:    var(--evolve-error,    #FF4D4D);
	--evolve-aivm-success:  var(--evolve-success,  #00FF99);
	font-family: 'Inter', system-ui, -apple-system, sans-serif;
	color: var(--evolve-aivm-text);
	box-sizing: border-box;
	max-width: 980px;
	margin: 0 auto;
	padding: 24px 18px;
}
.evolve-aivm *,
.evolve-aivm *::before,
.evolve-aivm *::after { box-sizing: border-box; }

.evolve-aivm__intro { text-align: center; margin: 0 0 22px; }
.evolve-aivm__title {
	font-family: 'Poppins', sans-serif; font-weight: 900;
	color: var(--evolve-aivm-text);
	font-size: clamp(1.7rem, 4vw, 2.6rem);
	line-height: 1.05;
	letter-spacing: -0.02em;
	margin: 0 0 8px;
}
.evolve-aivm__subtitle { color: #D0D0D0; margin: 0 auto; max-width: 580px; font-size: 14.5px; line-height: 1.6; }

/* ---------- Progress bar ---------- */
.evolve-aivm__progress {
	height: 4px;
	background: var(--evolve-aivm-border);
	border-radius: 999px;
	overflow: hidden;
	margin: 14px 0 22px;
}
.evolve-aivm__progress-bar {
	height: 100%;
	background: linear-gradient(90deg, var(--evolve-aivm-accent), var(--evolve-aivm-accent-2));
	border-radius: 999px;
	width: 0%;
	transition: width .35s cubic-bezier(.2,.7,.2,1);
}

/* ---------- Card / step ---------- */
.evolve-aivm__card {
	background:
		linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)),
		var(--evolve-aivm-card);
	border: 1px solid var(--evolve-aivm-border);
	border-radius: 20px;
	padding: 24px 22px 18px;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	animation: evolve-aivm-fade .35s cubic-bezier(.2,.7,.2,1);
}
@keyframes evolve-aivm-fade {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}
.evolve-aivm__step {
	display: inline-block;
	color: var(--evolve-aivm-accent);
	font-family: 'Poppins', sans-serif;
	font-weight: 700; font-size: 11px;
	letter-spacing: .14em; text-transform: uppercase;
	margin-bottom: 8px;
}
.evolve-aivm__qtitle {
	color: var(--evolve-aivm-text);
	font-family: 'Poppins', sans-serif;
	font-weight: 800; font-size: clamp(1.2rem, 3vw, 1.6rem);
	line-height: 1.2; margin: 0 0 18px;
}

.evolve-aivm__body { margin-bottom: 18px; }

/* ---------- Choice grid (tap-friendly cards) ---------- */
.evolve-aivm__choices {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px;
}
@media (min-width: 640px) { .evolve-aivm__choices { grid-template-columns: repeat(3, 1fr); } }

.evolve-aivm__option {
	display: flex; flex-direction: column; gap: 4px;
	min-height: 76px;
	background: var(--evolve-aivm-card-2) !important;
	color: var(--evolve-aivm-text) !important;
	border: 1px solid var(--evolve-aivm-border) !important;
	border-radius: 14px !important;
	padding: 14px 16px !important;
	text-align: left;
	cursor: pointer;
	transition: all .22s cubic-bezier(.2,.7,.2,1);
	font: inherit;
	box-shadow: none !important;
}
.evolve-aivm__option strong { color: var(--evolve-aivm-text); font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 14px; }
.evolve-aivm__option span   { color: var(--evolve-aivm-dim); font-size: 12px; line-height: 1.4; }
.evolve-aivm__option:hover,
.evolve-aivm__option:focus {
	border-color: var(--evolve-aivm-accent) !important;
	transform: translateY(-1px);
	box-shadow: 0 0 16px rgba(183,255,0,0.15) !important;
}
.evolve-aivm__option.is-selected {
	border-color: var(--evolve-aivm-accent) !important;
	background: rgba(183,255,0,0.08) !important;
	box-shadow: 0 0 22px rgba(183,255,0,0.25) !important;
}
.evolve-aivm__option.is-selected strong { color: var(--evolve-aivm-accent); }

/* ---------- Inputs ---------- */
.evolve-aivm__input {
	width: 100%;
	background: var(--evolve-aivm-card-2) !important;
	border: 1px solid var(--evolve-aivm-border) !important;
	color: var(--evolve-aivm-text) !important;
	border-radius: 14px !important;
	padding: 14px 16px !important;
	font-size: 16px !important; /* iOS no-zoom */
	font-family: inherit !important;
	outline: none !important;
	transition: all .22s ease;
}
.evolve-aivm__input:focus {
	border-color: var(--evolve-aivm-accent) !important;
	box-shadow: 0 0 14px rgba(183,255,0,0.18) !important;
}
.evolve-aivm__input::placeholder { color: var(--evolve-aivm-mute); }

/* ---------- Pills (flavor chips) ---------- */
.evolve-aivm__pills-wrap { display: flex; flex-direction: column; gap: 14px; }
.evolve-aivm__pills { display: flex; flex-wrap: wrap; gap: 8px; }

/* Multi-select pill variant — slightly bigger touch target + "+" / "✓" affordance */
.evolve-aivm__pills--multi { gap: 10px; }
.evolve-aivm__pills--multi .evolve-aivm__pill {
	display: inline-flex !important;
	align-items: center;
	gap: 6px;
	padding: 10px 14px 10px 12px !important;
}
.evolve-aivm__pill-mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px; height: 18px;
	border-radius: 999px;
	background: rgba(255,255,255,0.06);
	color: var(--evolve-aivm-dim);
	font-size: 14px;
	font-weight: 800;
	line-height: 1;
	transition: all .22s ease;
}
.evolve-aivm__pill.is-selected .evolve-aivm__pill-mark {
	background: #000;
	color: var(--evolve-aivm-accent);
	content: "✓";
}
.evolve-aivm__pill.is-selected .evolve-aivm__pill-mark::before { content: "✓"; }
.evolve-aivm__pill.is-selected .evolve-aivm__pill-mark { font-size: 0; }
.evolve-aivm__pill.is-selected .evolve-aivm__pill-mark::before { font-size: 12px; }

/* Friendly hint + count caption beneath the pill grid */
.evolve-aivm__hint {
	color: #C8C8C8 !important;
	font-size: 13px;
	line-height: 1.5;
	margin: 0;
}
.evolve-aivm__pill-count {
	margin: 4px 0 0;
	color: var(--evolve-aivm-accent);
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	font-size: 11.5px;
	letter-spacing: .14em;
	text-transform: uppercase;
}
.evolve-aivm__pill {
	background: var(--evolve-aivm-card-2) !important;
	color: var(--evolve-aivm-dim) !important;
	border: 1px solid var(--evolve-aivm-border) !important;
	border-radius: 999px !important;
	padding: 8px 16px !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	cursor: pointer;
	font-family: inherit;
	transition: all .22s ease;
}
.evolve-aivm__pill:hover { border-color: var(--evolve-aivm-accent) !important; color: var(--evolve-aivm-accent) !important; }
.evolve-aivm__pill.is-selected {
	background: var(--evolve-aivm-accent) !important;
	color: #000 !important;
	border-color: var(--evolve-aivm-accent) !important;
}

/* ---------- Slider ---------- */
.evolve-aivm__slider-wrap { text-align: center; }
.evolve-aivm__slider-value {
	font-family: 'Poppins', sans-serif;
	font-weight: 900;
	font-size: 56px;
	color: var(--evolve-aivm-accent);
	line-height: 1;
	margin: 4px 0 18px;
	text-shadow: 0 0 24px rgba(183,255,0,0.4);
}
.evolve-aivm__slider {
	width: 100%;
	-webkit-appearance: none;
	appearance: none;
	height: 6px;
	background: linear-gradient(90deg, var(--evolve-aivm-card-2), var(--evolve-aivm-card-2));
	border-radius: 999px;
	outline: none;
}
.evolve-aivm__slider::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 24px; height: 24px; border-radius: 50%;
	background: var(--evolve-aivm-accent);
	border: 2px solid #000;
	box-shadow: 0 0 16px rgba(183,255,0,0.6);
	cursor: pointer;
}
.evolve-aivm__slider::-moz-range-thumb {
	width: 24px; height: 24px; border-radius: 50%;
	background: var(--evolve-aivm-accent);
	border: 2px solid #000;
	box-shadow: 0 0 16px rgba(183,255,0,0.6);
	cursor: pointer;
}
.evolve-aivm__slider-labels {
	display: flex; justify-content: space-between;
	color: var(--evolve-aivm-mute);
	font-size: 11px;
	letter-spacing: .08em;
	text-transform: uppercase;
	margin-top: 10px;
	font-weight: 600;
}

/* ---------- Budget row ---------- */
.evolve-aivm__budget { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.evolve-aivm__field { display: flex; flex-direction: column; gap: 6px; }
.evolve-aivm__field > span {
	color: var(--evolve-aivm-dim);
	font-family: 'Poppins', sans-serif;
	font-weight: 600; font-size: 11px;
	letter-spacing: .12em; text-transform: uppercase;
}

/* ---------- Age confirmation ---------- */
.evolve-aivm__age {
	background: rgba(183,255,0,0.06);
	border: 1px solid rgba(183,255,0,0.30);
	border-radius: 14px;
	padding: 20px;
}
.evolve-aivm__age-text {
	color: #E8E8E8 !important;
	margin: 0 0 14px;
	font-size: 14.5px;
	line-height: 1.6;
	font-weight: 500;
}
.evolve-aivm__check {
	display: flex; align-items: center; gap: 12px;
	cursor: pointer;
	color: #FFFFFF !important;
	font-size: 15px;
	font-weight: 600;
}
.evolve-aivm__check input { display: none; }
.evolve-aivm__checkmark {
	flex: 0 0 20px; width: 20px; height: 20px;
	border: 1px solid var(--evolve-aivm-border);
	border-radius: 6px;
	background: var(--evolve-aivm-card-2);
	position: relative;
	transition: all .25s ease;
}
.evolve-aivm__check input:checked + .evolve-aivm__checkmark {
	background: var(--evolve-aivm-accent);
	border-color: var(--evolve-aivm-accent);
	box-shadow: 0 0 14px rgba(183,255,0,0.4);
}
.evolve-aivm__check input:checked + .evolve-aivm__checkmark::after {
	content: ""; position: absolute;
	left: 6px; top: 2px;
	width: 5px; height: 11px;
	border: solid #000;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

/* ---------- Nav buttons ---------- */
.evolve-aivm__nav { display: flex; justify-content: space-between; gap: 10px; margin-top: 8px; }
.evolve-aivm__btn {
	background: var(--evolve-aivm-accent) !important;
	color: #000 !important;
	border: 0 !important;
	border-radius: 14px !important;
	padding: 13px 24px !important;
	font-family: 'Poppins', sans-serif !important;
	font-weight: 700 !important;
	font-size: 13px !important;
	letter-spacing: .12em !important;
	text-transform: uppercase !important;
	cursor: pointer;
	transition: all .22s ease;
	min-height: 48px;
	box-shadow: none !important;
}
.evolve-aivm__btn:hover {
	background: var(--evolve-aivm-accent-2) !important;
	box-shadow: 0 0 22px rgba(183,255,0,0.35) !important;
	transform: translateY(-1px);
}
.evolve-aivm__btn--ghost {
	background: transparent !important;
	color: #E8E8E8 !important;
	border: 1px solid rgba(255,255,255,0.25) !important;
}
.evolve-aivm__btn--ghost:hover {
	color: #000 !important;
	background: var(--evolve-aivm-accent) !important;
	border-color: var(--evolve-aivm-accent) !important;
	box-shadow: 0 0 18px rgba(183,255,0,0.25) !important;
}
.evolve-aivm__error {
	margin-top: 12px;
	padding: 10px 14px;
	background: rgba(255,77,77,0.10);
	border: 1px solid rgba(255,77,77,0.45);
	color: #FF8B8B;
	border-radius: 12px;
	font-size: 13px;
}

/* ---------- Loading ---------- */
.evolve-aivm__loading {
	text-align: center;
	padding: 60px 20px;
	color: var(--evolve-aivm-dim);
}
.evolve-aivm__spinner {
	width: 44px; height: 44px;
	border: 3px solid rgba(183,255,0,0.18);
	border-top-color: var(--evolve-aivm-accent);
	border-radius: 50%;
	animation: evolve-aivm-spin 1s linear infinite;
	margin: 0 auto 18px;
}
@keyframes evolve-aivm-spin { to { transform: rotate(360deg); } }
.evolve-aivm__empty { text-align: center; padding: 40px 20px; color: var(--evolve-aivm-dim); }

/* ============================================================================
   Results
   ========================================================================= */
.evolve-aivm__section { margin-top: 28px; }
.evolve-aivm__section-eyebrow {
	display: inline-block;
	color: var(--evolve-aivm-accent);
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	font-size: 11px;
	letter-spacing: .18em;
	text-transform: uppercase;
	margin-bottom: 10px;
}
.evolve-aivm__section-title {
	color: var(--evolve-aivm-text);
	font-family: 'Poppins', sans-serif;
	font-weight: 800;
	font-size: clamp(1.1rem, 2.4vw, 1.4rem);
	margin: 0 0 14px;
}

.evolve-aivm__primary .evolve-aivm-card {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
	gap: 22px;
	padding: 24px;
}
@media (max-width: 720px) {
	.evolve-aivm__primary .evolve-aivm-card { grid-template-columns: 1fr; }
}

.evolve-aivm__grid {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	gap: 14px;
}
@media (min-width: 540px) { .evolve-aivm__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 860px) { .evolve-aivm__grid { grid-template-columns: repeat(3, 1fr); } }

.evolve-aivm-card {
	position: relative;
	background: var(--evolve-aivm-card);
	border: 1px solid var(--evolve-aivm-border);
	border-radius: 18px;
	overflow: hidden;
	transition: all .25s cubic-bezier(.2,.7,.2,1);
	display: flex;
	flex-direction: column;
}
.evolve-aivm-card:hover {
	border-color: var(--evolve-aivm-accent);
	transform: translateY(-3px);
	box-shadow: 0 0 22px rgba(183,255,0,0.22);
}
.evolve-aivm-card--primary {
	border-color: rgba(183,255,0,0.4);
	box-shadow: 0 0 32px rgba(183,255,0,0.18);
}
.evolve-aivm-card__media {
	display: block;
	background: #fff;
	aspect-ratio: 1 / 1;
	overflow: hidden;
}
.evolve-aivm-card--primary .evolve-aivm-card__media { aspect-ratio: auto; max-height: 320px; }
.evolve-aivm-card__media img {
	width: 100%; height: 100%;
	object-fit: contain;
	display: block;
	transition: transform .4s ease;
}
.evolve-aivm-card:hover .evolve-aivm-card__media img { transform: scale(1.04); }
.evolve-aivm-card__body {
	padding: 14px 16px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
}
.evolve-aivm__label {
	position: absolute;
	top: 12px; left: 12px;
	background: var(--evolve-aivm-accent);
	color: #000;
	font-family: 'Poppins', sans-serif;
	font-weight: 800;
	font-size: 10px;
	letter-spacing: .14em;
	padding: 4px 10px;
	border-radius: 999px;
	text-transform: uppercase;
	box-shadow: 0 0 14px rgba(183,255,0,0.4);
	z-index: 2;
}
.evolve-aivm-card__title {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	color: var(--evolve-aivm-text);
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	font-size: 15px;
	line-height: 1.3;
	text-decoration: none;
}
.evolve-aivm-card__title:hover { color: var(--evolve-aivm-accent); }
.evolve-aivm-card__price { color: var(--evolve-aivm-accent); font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 16px; }
.evolve-aivm-card__price del { color: var(--evolve-aivm-mute); opacity: 0.6; font-weight: 400; margin-right: 6px; }
.evolve-aivm__pct {
	display: inline-block;
	width: fit-content;
	background: rgba(183,255,0,0.12);
	border: 1px solid rgba(183,255,0,0.4);
	color: var(--evolve-aivm-accent);
	font-family: 'Poppins', sans-serif;
	font-weight: 800;
	font-size: 11px;
	letter-spacing: .08em;
	padding: 3px 9px;
	border-radius: 999px;
}
.evolve-aivm__reason {
	color: var(--evolve-aivm-dim);
	font-size: 13px;
	line-height: 1.5;
	margin: 0;
	font-style: italic;
}
.evolve-aivm-card__cta { display: flex; gap: 6px; margin-top: auto; padding-top: 6px; }
.evolve-aivm-card__add {
	flex: 1;
	background: var(--evolve-aivm-accent) !important;
	color: #000 !important;
	border: 0 !important;
	border-radius: 12px !important;
	padding: 11px 14px !important;
	font-family: 'Poppins', sans-serif !important;
	font-weight: 700 !important;
	font-size: 11.5px !important;
	letter-spacing: .1em !important;
	text-transform: uppercase !important;
	cursor: pointer;
	transition: all .22s ease;
}
.evolve-aivm-card__add:hover { background: var(--evolve-aivm-accent-2) !important; }
.evolve-aivm-card__add.is-loading { opacity: .7; cursor: progress; }
.evolve-aivm-card__add.is-added {
	background: rgba(0,255,153,0.15) !important;
	color: var(--evolve-aivm-success) !important;
}
.evolve-aivm-card__view {
	display: inline-flex; align-items: center;
	padding: 11px 14px;
	background: transparent;
	color: var(--evolve-aivm-dim);
	border: 1px solid var(--evolve-aivm-border);
	border-radius: 12px;
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	font-size: 11.5px;
	letter-spacing: .1em;
	text-transform: uppercase;
	text-decoration: none;
	transition: all .22s ease;
}
.evolve-aivm-card__view:hover { color: var(--evolve-aivm-accent); border-color: var(--evolve-aivm-accent); }

.evolve-aivm__footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	margin-top: 28px;
	padding-top: 18px;
	border-top: 1px solid var(--evolve-aivm-border);
	flex-wrap: wrap;
}
.evolve-aivm__source {
	color: var(--evolve-aivm-mute);
	font-size: 11px;
	letter-spacing: .08em;
	text-transform: uppercase;
}

/* ============================================================================
   Floating FAB
   ========================================================================= */
.evolve-aivm-fab {
	position: fixed;
	bottom: 24px; right: 24px;
	background: var(--evolve-aivm-accent, #B7FF00);
	color: #000;
	border: 0;
	padding: 12px 20px;
	border-radius: 999px;
	font-family: 'Poppins', sans-serif;
	font-weight: 800;
	font-size: 12px;
	letter-spacing: .12em;
	text-transform: uppercase;
	cursor: pointer;
	z-index: 9990;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	box-shadow: 0 8px 28px rgba(183,255,0,0.35), 0 0 0 0 rgba(183,255,0,0.5);
	transition: all .25s ease;
	animation: evolve-aivm-fab-pulse 2.4s ease-in-out infinite;
}
.evolve-aivm-fab:hover { transform: translateY(-2px); box-shadow: 0 12px 36px rgba(183,255,0,0.5); }
@keyframes evolve-aivm-fab-pulse {
	0%, 100% { box-shadow: 0 8px 28px rgba(183,255,0,0.35), 0 0 0 0 rgba(183,255,0,0.45); }
	50%      { box-shadow: 0 8px 28px rgba(183,255,0,0.35), 0 0 0 12px rgba(183,255,0,0); }
}

/* ============================================================================
   Modal mount (used when FAB clicked but no inline shortcode on the page)
   ========================================================================= */
.evolve-aivm-modal {
	position: fixed; inset: 0;
	background: rgba(5,5,5,0.85);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	z-index: 9999;
	display: none;
	align-items: flex-start;
	justify-content: center;
	overflow-y: auto;
	padding: 24px 12px;
}
.evolve-aivm-modal.is-open { display: flex; }
.evolve-aivm-modal__inner {
	position: relative;
	background: var(--evolve-aivm-bg, #050505);
	border: 1px solid #1E1E1E;
	border-radius: 20px;
	width: 100%;
	max-width: 900px;
}
.evolve-aivm-modal__close {
	position: absolute;
	top: 12px; right: 12px;
	width: 36px; height: 36px;
	border-radius: 999px;
	background: transparent;
	color: #FFFFFF;
	border: 1px solid #1E1E1E;
	font-size: 22px;
	line-height: 1;
	cursor: pointer;
	z-index: 2;
}
.evolve-aivm-modal__close:hover { color: var(--evolve-aivm-accent, #B7FF00); border-color: var(--evolve-aivm-accent, #B7FF00); }

/* Respect motion preferences */
@media (prefers-reduced-motion: reduce) {
	.evolve-aivm__card,
	.evolve-aivm-card,
	.evolve-aivm-fab { animation: none !important; transition: none !important; }
}
