/**
 * vPlugin Xem Màu Sơn Phong Thủy – Giao diện shortcode
 * Class prefix: vpmspt- (dễ đọc, tránh conflict)
 */

/* ---- Biến (tương tự Tailwind reference) ---- */
:root {
	--vpmspt-primary: #3B82F6;
	--vpmspt-primary-hover: #2563eb;
	--vpmspt-bg: #F8FAFC;
	--vpmspt-bg-card: #ffffff;
	--vpmspt-border: #e2e8f0;
	--vpmspt-text: #1e293b;
	--vpmspt-text-muted: #64748b;
	--vpmspt-input-bg: #f1f5f9;
	--vpmspt-radius: 0.5rem;
	--vpmspt-radius-lg: 0.5rem;
	--vpmspt-shadow: 0 1px 3px rgba(0,0,0,0.08);
	--vpmspt-shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1);
}

/* Dark mode */
.vpmspt-wrap.dark,
body.vpmspt-dark .vpmspt-wrap {
	--vpmspt-bg: #0F172A;
	--vpmspt-bg-card: #1e293b;
	--vpmspt-border: #334155;
	--vpmspt-text: #e2e8f0;
	--vpmspt-text-muted: #94a3b8;
	--vpmspt-input-bg: #0f172a;
}

/* ---- Wrapper ---- */
.vpmspt-wrap {
	
	color: var(--vpmspt-text);
	
	box-sizing: border-box;
	
	margin: 0 auto;
	
	transition: background-color 0.2s, color 0.2s;
}

/* ---- Header ---- */
.vpmspt-header {
	text-align: center;
	margin-bottom: 2.5rem;
}

.vpmspt-title {
	font-size: 1.875rem;
	font-weight: 700;
	color: var(--vpmspt-text);
	margin: 0 0 0.5rem;
}

.vpmspt-subtitle {
	font-size: 1rem;
	color: var(--vpmspt-text-muted);
	margin: 0;
}

@media (min-width: 768px) {
	.vpmspt-title { font-size: 2.25rem; }
}

/* ---- Form card ---- */
.vpmspt-form-card {
	background: var(--vpmspt-bg-card);
	border-radius: var(--vpmspt-radius-lg);
	box-shadow: var(--vpmspt-shadow);
	border: 1px solid var(--vpmspt-border);
	padding: 1.5rem;
	margin-bottom: 2rem;
}

.vpmspt-form-hint {
	margin: 0 0 1rem;
	color: var(--vpmspt-text);
	font-size: 0.9375rem;
}

.vpmspt-form-card .vpmspt-select {
	padding-left: 0.75rem;
}

.vpmspt-form-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem 1.5rem;
	align-items: end;
}

@media (min-width: 768px) {
	.vpmspt-form-grid { grid-template-columns: 1fr 1fr 1fr 1fr auto; }
}

@media (max-width: 767px) {
	.vpmspt-form-grid .vpmspt-field:last-child {
		grid-column: 1 / -1;
	}
	.vpmspt-form-grid .vpmspt-field .vpmspt-btn {
		width: 100%;
	}
}

/* ---- Field ---- */
.vpmspt-field {
	display: flex;
	flex-direction: column;
}

.vpmspt-field-label {
	display: block;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--vpmspt-text);
	margin-bottom: 0.5rem;
}

.vpmspt-input-wrap {
	position: relative;
}

.vpmspt-input-icon {
	position: absolute;
	left: 0.75rem;
	top: 50%;
	transform: translateY(-50%);
	color: var(--vpmspt-text-muted);
	font-size: 1.25rem;
	pointer-events: none;
}

.vpmspt-input,
.vpmspt-select {
	display: block;
	width: 100%;
	padding: 0.625rem 0.75rem;
	min-height: 45px;
	background: var(--vpmspt-input-bg);
	border: 1px solid var(--vpmspt-border);
	border-radius: var(--vpmspt-radius);
	font-size: 0.875rem;
	color: var(--vpmspt-text);
	box-sizing: border-box;
	transition: border-color 0.2s, box-shadow 0.2s;
}

.vpmspt-input:focus,
.vpmspt-select:focus {
	outline: none;
	border-color: var(--vpmspt-primary);
	box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
}

/* ---- Button ---- */
.vpmspt-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	background: var(--vpmspt-primary);
	color: #fff;
	font-weight: 600;
	font-size: 0.875rem;
	padding: 0.625rem 1.5rem;
	border: none;
	border-radius: var(--vpmspt-radius);
	box-shadow: 0 4px 14px rgba(59, 130, 246, 0.25);
	cursor: pointer;
	transition: background 0.2s, transform 0.15s;
}

.vpmspt-btn:hover {
	background: var(--vpmspt-primary-hover);
}

.vpmspt-btn:disabled {
	opacity: 0.7;
	cursor: not-allowed;
}

/* ---- Badge row (Mệnh Thủy | Tuổi Đinh Sửu) ---- */
.vpmspt-badge-row {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
	padding: 0 0.25rem;
}

.vpmspt-badge {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	border-radius: 9999px;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.vpmspt-badge--water { background: rgba(59, 130, 246, 0.2); color: #2563eb; }
.vpmspt-wrap.dark .vpmspt-badge--water { background: rgba(59, 130, 246, 0.3); color: #93c5fd; }
.vpmspt-badge--fire { background: rgba(239, 68, 68, 0.2); color: #dc2626; }
.vpmspt-badge--wood { background: rgba(34, 197, 94, 0.2); color: #16a34a; }
.vpmspt-badge--metal { background: rgba(148, 163, 184, 0.3); color: #475569; }
.vpmspt-badge--earth { background: rgba(180, 83, 9, 0.2); color: #b45309; }

.vpmspt-badge-text {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--vpmspt-text);
	margin: 0px !important;
}

.vpmspt-badge-text strong {
	color: var(--vpmspt-primary);
}

/* ---- Result card ---- */
.vpmspt-result-card {
	background: var(--vpmspt-bg-card);
	border-radius: 0.5rem;
	overflow: hidden;
	box-shadow: var(--vpmspt-shadow-lg);
	border: 1px solid var(--vpmspt-border);
}

.vpmspt-result-header {
	background: var(--vpmspt-primary);
	color: #fff;
	padding: 1rem 2rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	align-items: flex-start;
	justify-content: space-between;
}

@media (min-width: 768px) {
	.vpmspt-result-header { flex-direction: row; align-items: center; }
}

.vpmspt-color-main-title {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 1rem;
	color: var(--vpmspt-text);
}

.vpmspt-result-header-title {
	font-size: 1.125rem;
	font-weight: 600;
	margin: 0;
	color: #fff;
}

.vpmspt-result-header .vpmspt-btn {
	background: #fff;
	color: var(--vpmspt-primary);
}

.vpmspt-result-header .vpmspt-btn:hover {
	background: #f1f5f9;
}

/* ---- Color sections ---- */
.vpmspt-color-section {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	align-items: center;
	padding: 2rem;
	border-bottom: 1px solid var(--vpmspt-border);
}

.vpmspt-color-section:last-child {
	border-bottom: none;
}

@media (min-width: 768px) {
	.vpmspt-color-section { grid-template-columns: 1fr 3fr; }
}

.vpmspt-color-section--avoid {
	background: rgba(239, 68, 68, 0.08);
}

.vpmspt-wrap.dark .vpmspt-color-section--avoid {
	background: rgba(239, 68, 68, 0.12);
}

.vpmspt-color-title {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--vpmspt-text);
	margin: 0 0 0.25rem;
}

.vpmspt-color-section--avoid .vpmspt-color-title {
	color: #dc2626;
}

.vpmspt-wrap.dark .vpmspt-color-section--avoid .vpmspt-color-title {
	color: #f87171;
}

.vpmspt-color-subtitle {
	font-size: 0.75rem;
	color: var(--vpmspt-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-weight: 500;
	margin: 0;
}

.vpmspt-color-section--avoid .vpmspt-color-subtitle {
	color: #dc2626;
	opacity: 0.9;
}

.vpmspt-swatches {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
}

.vpmspt-swatches-inline {
	margin: 0.5rem 0 1rem;
}

/* ---- Bảng thông tin tuổi ---- */
.vpmspt-info-table-wrap {
	margin-bottom: 1.5rem;
}

.vpmspt-info-title {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 0.75rem;
	color: var(--vpmspt-text);
}

.vpmspt-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.875rem;
}

.vpmspt-table td {
	padding: 0.5rem 0.75rem;
	border: 1px solid var(--vpmspt-border);
}

.vpmspt-table tr td:first-child {
	background: var(--vpmspt-input-bg);
	font-weight: 500;
	width: 40%;
}

/* ---- Diễn giải kiểu devvn ---- */
.vpmspt-intro {
	font-size: 0.9375rem;
	color: var(--vpmspt-text-muted);
	line-height: 1.6;
	margin: 0 0 1.5rem;
}

.vpmspt-block-title {
	margin: 1rem 0 0.25rem;
	font-size: 0.9375rem;
	color: var(--vpmspt-text);
}

.vpmspt-block-desc {
	font-size: 0.875rem;
	color: var(--vpmspt-text-muted);
	line-height: 1.5;
	margin: 0 0 0.5rem;
}

.vpmspt-swatch {
	width: 44px;
	height: 44px;
	border-radius: 10px;
	box-shadow: inset 1px 2px 2px 2px rgb(24 24 24 / 8%);
	transition: transform 0.2s;
	flex-shrink: 0;
}

.vpmspt-swatch:hover {
	transform: scale(1.1);
}

/* ---- Prose (quote + lists) ---- */
.vpmspt-prose {
	margin-top: 3rem;
}

.vpmspt-quote {
	font-size: 1.125rem;
	font-style: italic;
	color: var(--vpmspt-text-muted);
	border-left: 4px solid var(--vpmspt-primary);
	padding-left: 1rem;
	margin: 0 0 2.5rem;
}

.vpmspt-prose-title {
	font-size: 1.5rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin: 2.5rem 0 1.5rem;
	color: var(--vpmspt-text);
}

.vpmspt-prose-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1.75rem;
	line-height: 1;
	flex-shrink: 0;
}

.vpmspt-prose-icon--check {
	color: #16a34a;
}

.vpmspt-wrap.dark .vpmspt-prose-icon--check {
	color: #4ade80;
}

.vpmspt-prose-icon--cancel {
	color: #dc2626;
}

.vpmspt-wrap.dark .vpmspt-prose-icon--cancel {
	color: #f87171;
}

.vpmspt-prose-section {
	margin-bottom: 2.5rem;
}

.vpmspt-prose-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.vpmspt-prose-item {
	margin-bottom: 1.5rem;
}

.vpmspt-prose-item:last-child {
	margin-bottom: 0;
}

.vpmspt-prose-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
}

.vpmspt-prose-tag {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	border-radius: 4px;
	font-size: 0.875rem;
	font-weight: 700;
	white-space: nowrap;
}

.vpmspt-prose-section--cancel .vpmspt-prose-tag {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

/* Grid + card cho phần Màu tương khắc (giống ảnh) */
.vpmspt-prose-list--cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.vpmspt-prose-list--cards {
		grid-template-columns: repeat(2, 1fr);
	}
}

.vpmspt-prose-card {
	background: var(--vpmspt-input-bg);
	border: 1px solid var(--vpmspt-border);
	border-radius: var(--vpmspt-radius-lg);
	padding: 1.25rem;
	box-shadow: var(--vpmspt-shadow);
}

.vpmspt-prose-card--full {
	grid-column: 1 / -1;
}

.vpmspt-prose-card .vpmspt-prose-item {
	margin-bottom: 0;
}

.vpmspt-prose-card .vpmspt-prose-tags {
	margin-bottom: 0.75rem;
}

.vpmspt-prose-card .vpmspt-prose-desc {
	font-size: 0.875rem;
	margin: 0;
}

.vpmspt-prose-tag--light {
	color: #fff;
}

.vpmspt-prose-tag--dark {
	color: #1e293b;
	border: 1px solid rgba(0, 0, 0, 0.12);
}

.vpmspt-wrap.dark .vpmspt-prose-tag--dark {
	color: #e2e8f0;
	border-color: rgba(255, 255, 255, 0.2);
}

.vpmspt-prose-desc {
	font-size: 0.875rem;
	color: var(--vpmspt-text-muted);
	margin: 0;
	line-height: 1.6;
}

/* ---- Loading ---- */
.vpmspt-result-area {
	position: relative;
	min-height: 200px;
}

.vpmspt-result-area.vpmspt-loading {
	opacity: 0.6;
	pointer-events: none;
}

.vpmspt-result-area.vpmspt-loading::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 48px;
	height: 48px;
	margin: -24px 0 0 -24px;
	border: 4px solid var(--vpmspt-border);
	border-top-color: var(--vpmspt-primary);
	border-radius: 50%;
	animation: vpmspt-spin 0.8s linear infinite;
}

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

/* ---- Nội dung ban đầu (ẩn khi có kết quả) ---- */
.vpmspt-initial-content.vpmspt-hidden {
	display: none;
}

/* ---- Footer ---- */
.vpmspt-footer {
	margin-top: 4rem;
	padding-top: 2rem;
	border-top: 1px solid var(--vpmspt-border);
	text-align: center;
}

.vpmspt-footer p {
	font-size: 0.75rem;
	color: var(--vpmspt-text-muted);
	margin: 0;
}
