/* Plasma Stream 2026 — Homepage Portal Base (home.tpl) */

.home-page {
	color: var(--hp-text);
	margin: -10px 0 30px;
	font-family: var(--hp-font-body);
}

/* Hero — Plasma Mesh */
.home-hero {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	background: var(--hp-dark);
	border-radius: var(--hp-radius-xl);
	padding: 48px 36px;
	margin-bottom: 32px;
	overflow: hidden;
	border: 1px solid var(--hp-orange-border);
	box-shadow: var(--hp-shadow-lg), inset 0 1px 0 rgba(255,255,255,0.04);
	animation: hp-fadeUp 0.7s var(--hp-ease-out) both;
}

.home-hero::before {
	content: '';
	position: absolute;
	inset: -50%;
	background:
		radial-gradient(ellipse 50% 70% at 85% 15%, var(--hp-orange-mesh) 0%, transparent 55%),
		radial-gradient(ellipse 35% 50% at 5% 85%, rgba(0, 230, 118, 0.05) 0%, transparent 45%),
		radial-gradient(ellipse 60% 40% at 50% 100%, rgba(255, 69, 0, 0.08) 0%, transparent 50%);
	animation: hp-meshShift 12s ease-in-out infinite;
	pointer-events: none;
}

.home-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	opacity: 0.04;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
	pointer-events: none;
}

.home-hero-inner {
	position: relative;
	z-index: 1;
}

.home-hero-visual {
	display: none;
	position: relative;
	align-items: center;
	justify-content: center;
	min-height: 200px;
}

.home-hero-orb {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 180px;
	height: 180px;
	border-radius: 50%;
	background: transparent;
	box-shadow: none;
	overflow: visible;
}

.home-hero-orb::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: radial-gradient(circle at 30% 30%, var(--hp-orange-hover, #ff5722), var(--hp-orange-dark, #e63900));
	box-shadow: 0 0 60px var(--hp-orange-glow), 0 0 120px rgba(255, 69, 0, 0.15);
	z-index: 0;
}

.home-hero-orb.hp-animate-plasma {
	animation: none;
}

.home-hero-orb.hp-animate-plasma::before {
	animation: hp-plasmaPulse 4s ease-in-out infinite;
}

.home-hero-orb::after {
	content: '';
	position: absolute;
	inset: -4px;
	border-radius: 50%;
	border: 1px dashed var(--hp-orange-border, rgba(255, 69, 0, 0.32));
	box-shadow: 0 0 20px rgba(255, 69, 0, 0.15);
	z-index: 1;
	pointer-events: none;
	animation: hp-ringOrbit 14s linear infinite;
}

.home-hero-orb__img {
	display: block;
	width: 60%;
	height: 60%;
	object-fit: contain;
	position: relative;
	z-index: 2;
	filter: drop-shadow(0 10px 28px rgba(255, 69, 0, 0.35));
	pointer-events: none;
	user-select: none;
}

.home-hero-orb-ring {
	position: absolute;
	width: 190px;
	height: 190px;
	border-radius: 50%;
	border: 1px dashed var(--hp-orange-border);
	animation: hp-ringOrbit 14s linear infinite;
}

.home-hero-orb-ring:nth-child(2) {
	width: 220px;
	height: 220px;
	border-style: solid;
	border-color: rgba(255, 69, 0, 0.12);
	animation-duration: 20s;
	animation-direction: reverse;
}

.home-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--hp-orange-soft);
	border: 1px solid var(--hp-orange-border);
	color: var(--hp-orange);
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	padding: 5px 14px;
	border-radius: 999px;
	margin-bottom: 20px;
	backdrop-filter: blur(8px);
}

.home-badge i {
	font-size: 0.85em;
	animation: hp-badgePulse 2.5s ease-in-out infinite;
}

.home-hero h1,
.home-hero h2 {
	font-family: var(--hp-font-display);
	font-size: clamp(2.2rem, 7vw, 3.8rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	color: var(--hp-text);
	margin: 0 0 14px;
	line-height: 1;
}

.home-hero h1 span,
.home-hero h2 span {
	background: linear-gradient(135deg, var(--hp-orange), var(--hp-orange-hover));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.home-hero p {
	margin: 0 0 32px;
	font-size: 1rem;
	color: var(--hp-text-muted);
	max-width: 460px;
	line-height: 1.7;
}

.home-hero-actions {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
}

.home-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 24px;
	border-radius: 12px;
	font-size: var(--hp-text-base, 14px);
	font-weight: 700;
	line-height: 1.25;
	text-decoration: none;
	transition: transform 0.25s var(--hp-ease-out), box-shadow var(--hp-transition), background var(--hp-transition);
}

.home-btn i {
	font-size: 0.95em;
}

.home-btn:hover {
	transform: translateY(-3px);
	text-decoration: none;
}

.home-btn-primary {
	background: linear-gradient(135deg, var(--hp-orange), var(--hp-orange-dark));
	color: #fff !important;
	box-shadow: 0 6px 24px var(--hp-orange-glow);
}

.home-btn-primary:hover {
	color: #fff !important;
	box-shadow: 0 12px 36px rgba(255, 69, 0, 0.5);
}

.home-btn-secondary {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--hp-border-strong);
	color: var(--hp-text) !important;
	backdrop-filter: blur(12px);
}

.home-btn-secondary:hover {
	background: var(--hp-orange-soft);
	border-color: var(--hp-orange-border);
	color: var(--hp-orange) !important;
}

/* Stats strip */
.home-stats {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	margin-bottom: 32px;
	list-style: none;
	padding: 0;
}

.home-stat {
	position: relative;
	background: var(--hp-glass);
	backdrop-filter: blur(var(--hp-blur));
	border: 1px solid var(--hp-border);
	border-radius: var(--hp-radius-lg);
	padding: 24px 20px;
	text-align: center;
	box-shadow: var(--hp-shadow);
	transition: transform 0.3s var(--hp-ease-out), border-color var(--hp-transition), box-shadow var(--hp-transition);
	overflow: hidden;
	animation:
		hp-fadeUp 0.55s var(--hp-ease-out) both,
		hp-statAttention 3.2s ease-in-out infinite;
}

.home-stat::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: linear-gradient(90deg, var(--hp-orange), var(--hp-orange-hover), transparent);
	animation: hp-statBarShine 2.5s ease-in-out infinite;
}

.home-stat:hover {
	transform: translateY(-4px);
	border-color: var(--hp-orange-border);
	box-shadow: var(--hp-shadow-lg);
	animation-play-state: paused;
}

.home-stat:hover::before,
.home-stat:hover .num {
	animation-play-state: paused;
}

.home-stat:nth-child(1) {
	animation-delay: 0.1s, 0.85s;
}

.home-stat:nth-child(2) {
	animation-delay: 0.18s, 1.15s;
}

.home-stat:nth-child(3) {
	animation-delay: 0.26s, 1.45s;
}

.home-stat .num {
	font-family: var(--hp-font-display);
	font-size: 2.6rem;
	font-weight: 800;
	color: var(--hp-orange);
	line-height: 1;
	display: block;
	animation: hp-statNumGlow 2.8s ease-in-out infinite;
}

.home-stat:nth-child(1) .num { animation-delay: 0s; }
.home-stat:nth-child(2) .num { animation-delay: 0.35s; }
.home-stat:nth-child(3) .num { animation-delay: 0.7s; }

.home-stat .lbl {
	font-size: var(--hp-text-xs);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--hp-text-muted);
	font-weight: 700;
	margin-top: 8px;
	display: block;
}

/* Bento grid */
.home-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
	margin-bottom: 32px;
}

.home-card {
	position: relative;
	background: var(--hp-surface-2);
	border: 1px solid var(--hp-border);
	border-radius: var(--hp-radius-lg);
	padding: 28px 24px;
	text-decoration: none;
	color: var(--hp-text) !important;
	display: flex;
	flex-direction: column;
	gap: 12px;
	min-height: 200px;
	transition: transform 0.3s var(--hp-ease-out), border-color var(--hp-transition), box-shadow var(--hp-transition);
	box-shadow: var(--hp-shadow);
	animation: hp-fadeUp 0.55s var(--hp-ease-out) both;
	overflow: hidden;
}

.home-card::after {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%), var(--hp-orange-soft) 0%, transparent 55%);
	opacity: 0;
	transition: opacity var(--hp-transition);
	pointer-events: none;
}

.home-card:hover {
	transform: translateY(-8px);
	border-color: var(--hp-orange-border);
	box-shadow: var(--hp-shadow-lg), 0 0 40px rgba(255, 69, 0, 0.06);
	color: var(--hp-text) !important;
	text-decoration: none;
}

.home-card:hover::after { opacity: 1; }

.home-card:nth-child(1) { animation-delay: 0.05s; grid-column: span 1; }
.home-card:nth-child(2) { animation-delay: 0.12s; }
.home-card:nth-child(3) { animation-delay: 0.19s; }
.home-card:nth-child(4) { animation-delay: 0.26s; }
.home-card:nth-child(5) { animation-delay: 0.33s; }
.home-card:nth-child(6) { animation-delay: 0.40s; }

.home-card-icon {
	width: 52px;
	height: 52px;
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	flex-shrink: 0;
	transition: transform 0.3s var(--hp-ease-spring);
}

.home-card:hover .home-card-icon {
	transform: scale(1.08) rotate(-3deg);
}

.home-card-icon.orange { background: var(--hp-orange-soft); color: var(--hp-orange); border: 1px solid var(--hp-orange-border); }
.home-card-icon.green  { background: rgba(0, 230, 118, 0.1); color: var(--hp-green); border: 1px solid rgba(0, 230, 118, 0.28); }
.home-card-icon.gold   { background: rgba(255, 193, 7, 0.1); color: var(--hp-gold); border: 1px solid rgba(255, 193, 7, 0.28); }
.home-card-icon.blue   { background: rgba(66, 165, 245, 0.1); color: var(--hp-blue); border: 1px solid rgba(66, 165, 245, 0.28); }

.home-card h3 {
	font-family: var(--hp-font-display);
	font-size: 1.2rem;
	font-weight: 700;
	margin: 0;
	color: var(--hp-text);
}

.home-card p {
	margin: 0;
	font-size: 0.875rem;
	color: var(--hp-text-muted);
	line-height: 1.6;
	flex: 1;
}

.home-card-arrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: var(--hp-text-xs);
	color: var(--hp-orange);
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	margin-top: auto;
	transition: gap 0.25s var(--hp-ease-out);
}

.home-card:hover .home-card-arrow { gap: 14px; }
.home-card:hover .home-card-arrow i { animation: hp-slideArrow 0.4s var(--hp-ease-out) forwards; }

.home-card-featured {
	border-color: var(--hp-orange-border) !important;
	box-shadow: var(--hp-shadow-lg), 0 0 30px rgba(255, 69, 0, 0.08);
}

.home-card-badge {
	position: absolute;
	top: 16px;
	right: 16px;
	padding: 4px 10px;
	font-size: var(--hp-text-xs);
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #fff;
	background: linear-gradient(135deg, var(--hp-orange), var(--hp-orange-dark));
	border-radius: 999px;
}

.home-card-meta {
	font-size: var(--hp-text-xs);
	font-weight: 700;
	color: var(--hp-orange);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.home-card-features {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.home-card-features li {
	font-size: var(--hp-text-sm);
	color: var(--hp-text-muted);
	display: flex;
	align-items: center;
	gap: 8px;
}

.home-card-features li .fa {
	color: var(--hp-green);
	font-size: 0.9em;
}

/* Footer note */
.home-footer-note {
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
	padding: 22px 28px;
	margin-bottom: 32px;
	background: linear-gradient(135deg, var(--hp-surface-1), rgba(255, 69, 0, 0.04));
	border: 1px solid var(--hp-orange-border);
	border-left: 4px solid var(--hp-orange);
	border-radius: var(--hp-radius-lg);
	box-shadow: var(--hp-shadow);
	animation: hp-fadeUp 0.55s var(--hp-ease-out) 0.4s both;
}

.home-footer-icon {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--hp-orange-soft);
	border: 1px solid var(--hp-orange-border);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.home-footer-icon i {
	color: var(--hp-orange);
	font-size: 18px;
}

.home-footer-text strong {
	font-family: var(--hp-font-display);
	font-size: 1rem;
	font-weight: 700;
	color: var(--hp-orange);
	display: block;
}

.home-footer-text span {
	font-size: 0.875rem;
	color: var(--hp-text-muted);
	line-height: 1.55;
}

/* Responsive bento */
@media (min-width: 600px) {
	.home-stats { grid-template-columns: repeat(3, 1fr); }
	.home-grid  { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 768px) {
	.home-hero {
		grid-template-columns: 1.2fr 0.8fr;
		align-items: center;
		padding: 56px 48px;
	}
	.home-hero-visual { display: flex; }
}

@media (min-width: 1024px) {
	.home-grid {
		grid-template-columns: repeat(3, 1fr);
	}
	.home-card:first-child {
		grid-row: span 2;
		min-height: 100%;
		justify-content: center;
	}
}

@media (max-width: 599px) {
	.home-hero { padding: 32px 22px; }
	.home-hero-actions { flex-direction: column; }
	.home-btn { justify-content: center; width: 100%; }
}

@media (max-width: 479px) {
	.home-hero { padding: 24px 16px; }
	.home-stat .num { font-size: 2rem; }
	.home-stat { padding: 18px 14px; }
	.home-card { padding: 22px 18px; min-height: 180px; }
}

@media (min-width: 600px) and (max-width: 767px) {
	.home-stats {
		grid-template-columns: repeat(3, 1fr);
		gap: 10px;
	}
	.home-stat {
		padding: 16px 12px;
	}
	.home-stat .num {
		font-size: 2rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.home-hero, .home-stat, .home-card, .home-footer-note,
	.home-badge i, .home-hero-orb, .home-hero-orb::before, .home-hero-orb::after,
	.home-hero-orb-ring, .home-hero::before {
		animation: none !important;
	}
}

/* FAQ — SEO + rich results */
.home-faq {
	margin-top: 8px;
	margin-bottom: 32px;
	padding: 32px 28px;
	background: var(--hp-surface-2);
	border: 1px solid var(--hp-border);
	border-radius: var(--hp-radius-lg);
	box-shadow: var(--hp-shadow);
}

.home-faq-header h2 {
	font-family: var(--hp-font-display);
	font-size: clamp(1.35rem, 3vw, 1.75rem);
	font-weight: 800;
	color: var(--hp-text);
	margin: 0 0 8px;
}

.home-faq-header p {
	color: var(--hp-text-muted);
	margin: 0 0 24px;
	font-size: 0.95rem;
}

.home-faq-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.home-faq-item {
	background: var(--hp-surface-1);
	border: 1px solid var(--hp-border);
	border-radius: var(--hp-radius-md);
	overflow: hidden;
	transition: border-color var(--hp-transition);
}

.home-faq-item[open] {
	border-color: var(--hp-orange-border);
}

.home-faq-item summary {
	cursor: pointer;
	padding: 16px 20px;
	font-weight: 700;
	color: var(--hp-text);
	list-style: none;
	position: relative;
	padding-right: 40px;
}

.home-faq-item summary::-webkit-details-marker { display: none; }

.home-faq-item summary::after {
	content: '+';
	position: absolute;
	right: 18px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--hp-orange);
	font-size: 1.25rem;
	font-weight: 700;
}

.home-faq-item[open] summary::after {
	content: '−';
}

.home-faq-item summary:focus-visible {
	outline: 2px solid var(--hp-orange);
	outline-offset: 2px;
}

.home-faq-answer {
	padding: 0 20px 16px;
	color: var(--hp-text-muted);
	font-size: 0.92rem;
	line-height: 1.6;
}

.home-faq-answer p { margin: 0; }
