/* ==========================================================================
   Pagina Sobre Nos
   ========================================================================== */

@keyframes vruumy-sobre-dot {
	0%, 100% { opacity: 1; }
	50%       { opacity: .2; }
}

@keyframes vruumy-sobre-float {
	0%, 100% { transform: translateY(0) scale(1); }
	50%       { transform: translateY(-14px) scale(1.04); }
}

@keyframes vruumy-sobre-float-2 {
	0%, 100% { transform: translateY(0) scale(1); }
	50%       { transform: translateY(10px) scale(.97); }
}

@keyframes vruumy-sobre-particle {
	0%   { transform: translateY(0) translateX(0) scale(1); opacity: .7; }
	100% { transform: translateY(-120px) translateX(var(--tx, 30px)) scale(0); opacity: 0; }
}

@keyframes vruumy-sobre-ring-spin {
	from { transform: translate(-50%, -50%) rotate(0deg); }
	to   { transform: translate(-50%, -50%) rotate(360deg); }
}

@keyframes vruumy-sobre-ring-spin-r {
	from { transform: translate(-50%, -50%) rotate(0deg); }
	to   { transform: translate(-50%, -50%) rotate(-360deg); }
}

@keyframes vruumy-sobre-pulse-glow {
	0%, 100% { opacity: .55; }
	50%       { opacity: 1; }
}

.vruumy-sobre {
	background: var(--vruumy-black);
	overflow-x: hidden;
}

/* ==========================================================================
   Hero
   ========================================================================== */
.vruumy-sobre__hero {
	position: relative;
	padding: clamp(5rem, 13vw, 10rem) clamp(1.25rem, 5vw, 3rem) clamp(4rem, 8vw, 6rem);
	text-align: center;
	overflow: hidden;
	isolation: isolate;
}

.vruumy-sobre__hero-grid {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(0, 178, 255, .055) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 45, 142, .045) 1px, transparent 1px);
	background-size: 48px 48px;
	mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, black 10%, transparent 72%);
	-webkit-mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, black 10%, transparent 72%);
	pointer-events: none;
}

.vruumy-sobre__hero-orbs {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.vruumy-sobre__orb {
	position: absolute;
	border-radius: 50%;
	filter: blur(72px);
}

.vruumy-sobre__orb--1 {
	width: 420px;
	height: 420px;
	background: rgba(0, 178, 255, .13);
	top: -80px;
	left: -60px;
	animation: vruumy-sobre-float 7s ease-in-out infinite;
}

.vruumy-sobre__orb--2 {
	width: 360px;
	height: 360px;
	background: rgba(255, 45, 142, .11);
	bottom: -60px;
	right: -40px;
	animation: vruumy-sobre-float-2 9s ease-in-out infinite;
}

.vruumy-sobre__orb--3 {
	width: 260px;
	height: 260px;
	background: rgba(130, 0, 255, .07);
	top: 40%;
	left: 55%;
	animation: vruumy-sobre-float 11s ease-in-out infinite reverse;
}

/* Particles */
.vruumy-sobre__particles {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.vruumy-sobre__particle {
	position: absolute;
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--vruumy-gradient);
	opacity: 0;
	animation: vruumy-sobre-particle 4s ease-out infinite;
}

.vruumy-sobre__particle:nth-child(1)  { left: 12%; top: 70%; animation-delay: 0s;    --tx: 20px; }
.vruumy-sobre__particle:nth-child(2)  { left: 25%; top: 80%; animation-delay: .6s;   --tx: -18px; }
.vruumy-sobre__particle:nth-child(3)  { left: 38%; top: 75%; animation-delay: 1.2s;  --tx: 14px; }
.vruumy-sobre__particle:nth-child(4)  { left: 52%; top: 82%; animation-delay: .3s;   --tx: -22px; }
.vruumy-sobre__particle:nth-child(5)  { left: 65%; top: 72%; animation-delay: .9s;   --tx: 16px; }
.vruumy-sobre__particle:nth-child(6)  { left: 78%; top: 78%; animation-delay: 1.5s;  --tx: -12px; }
.vruumy-sobre__particle:nth-child(7)  { left: 88%; top: 65%; animation-delay: .4s;   --tx: 24px; }
.vruumy-sobre__particle:nth-child(8)  { left: 6%;  top: 60%; animation-delay: 2s;    --tx: 10px; }
.vruumy-sobre__particle:nth-child(9)  { left: 44%; top: 85%; animation-delay: 2.4s;  --tx: -16px; }
.vruumy-sobre__particle:nth-child(10) { left: 70%; top: 88%; animation-delay: 1.8s;  --tx: 18px; }
.vruumy-sobre__particle:nth-child(11) { left: 33%; top: 90%; animation-delay: .7s;   --tx: -20px; }
.vruumy-sobre__particle:nth-child(12) { left: 58%; top: 92%; animation-delay: 3s;    --tx: 12px; }

.vruumy-sobre__hero > * { position: relative; z-index: 1; }

.vruumy-sobre__kicker {
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	font-family: var(--vruumy-font-heading);
	font-size: .62rem;
	font-weight: 700;
	letter-spacing: .28em;
	text-transform: uppercase;
	color: var(--vruumy-pink);
	margin: 0 0 2rem;
	padding: .5em 1.2em;
	border: 1px solid rgba(255, 45, 142, .3);
	border-radius: 999px;
	background: rgba(255, 45, 142, .06);
	backdrop-filter: blur(6px);
	box-shadow: 0 0 20px rgba(255, 45, 142, .16);
}

.vruumy-sobre__kicker .vruumy-icon svg { width: 13px; height: 13px; }

.vruumy-sobre__kicker-dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--vruumy-pink);
	box-shadow: 0 0 10px var(--vruumy-pink);
	animation: vruumy-sobre-dot 1.6s ease-in-out infinite;
	flex-shrink: 0;
}

.vruumy-sobre__title {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin: 0 0 1rem;
	line-height: 1;
}

.vruumy-sobre__title-top {
	font-family: var(--vruumy-font-heading);
	font-size: clamp(1.5rem, 4vw, 2.4rem);
	font-weight: 700;
	letter-spacing: .32em;
	text-transform: uppercase;
	color: var(--vruumy-text-muted);
}

.vruumy-sobre__title-brand {
	font-family: var(--vruumy-font-heading);
	font-size: clamp(4rem, 14vw, 9rem);
	font-weight: 900;
	letter-spacing: .06em;
	background: var(--vruumy-gradient);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	filter: drop-shadow(0 0 40px rgba(0, 178, 255, .55));
	line-height: .9;
}

.vruumy-sobre__title-dot {
	-webkit-text-fill-color: var(--vruumy-pink);
	color: var(--vruumy-pink);
	filter: drop-shadow(0 0 20px rgba(255, 45, 142, .8));
}

.vruumy-sobre__tagline {
	font-family: var(--vruumy-font-heading);
	font-size: clamp(.72rem, 2vw, .9rem);
	font-weight: 600;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--vruumy-text-muted);
	margin: 1.25rem 0 2.5rem;
}

.vruumy-sobre__hero-badges {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: .65rem;
}

.vruumy-sobre__hero-badge {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	padding: .45em 1em;
	border: 1px solid var(--vruumy-border);
	border-radius: 999px;
	background: rgba(255, 255, 255, .03);
	font-size: .7rem;
	font-weight: 600;
	letter-spacing: .08em;
	color: var(--vruumy-text-muted);
	backdrop-filter: blur(4px);
}

.vruumy-sobre__hero-badge .vruumy-icon { color: var(--vruumy-blue); }
.vruumy-sobre__hero-badge:nth-child(2n) .vruumy-icon { color: var(--vruumy-pink); }
.vruumy-sobre__hero-badge .vruumy-icon svg { width: 12px; height: 12px; }

/* ==========================================================================
   Manifesto
   ========================================================================== */
.vruumy-sobre__manifesto {
	padding: clamp(3rem, 7vw, 5rem) clamp(1.25rem, 5vw, 3rem);
	background: linear-gradient(180deg, rgba(0,178,255,.04) 0%, transparent 100%);
	border-top: 1px solid var(--vruumy-border);
	border-bottom: 1px solid var(--vruumy-border);
}

.vruumy-sobre__manifesto-inner {
	max-width: 960px;
	margin: 0 auto;
	display: flex;
	gap: 3rem;
	align-items: flex-start;
}

.vruumy-sobre__manifesto-accent {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	flex-shrink: 0;
	border-radius: 14px;
	background: linear-gradient(135deg, rgba(255,45,142,.16), rgba(0,178,255,.1));
	border: 1px solid rgba(255, 45, 142, .3);
	color: var(--vruumy-pink);
	box-shadow: 0 0 24px rgba(255, 45, 142, .2), inset 0 0 12px rgba(255, 45, 142, .06);
	animation: vruumy-sobre-pulse-glow 3s ease-in-out infinite;
	margin-top: .25rem;
}

.vruumy-sobre__manifesto-accent .vruumy-icon svg { width: 26px; height: 26px; }

.vruumy-sobre__manifesto-text { flex: 1; }

.vruumy-sobre__lead {
	font-family: var(--vruumy-font-heading);
	font-size: clamp(1rem, 2.5vw, 1.3rem);
	font-weight: 700;
	line-height: 1.55;
	letter-spacing: .02em;
	background: var(--vruumy-gradient);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	margin: 0 0 1.25rem;
}

.vruumy-sobre__manifesto-text p {
	margin: 0 0 1rem;
	font-size: clamp(.9rem, 1.8vw, 1rem);
	line-height: 1.85;
	color: rgba(210, 210, 230, .88);
}

.vruumy-sobre__manifesto-text p:last-child { margin: 0; }

/* ==========================================================================
   Pilares
   ========================================================================== */
.vruumy-sobre__pilares {
	padding: clamp(4rem, 9vw, 7rem) clamp(1.25rem, 5vw, 3rem);
}

.vruumy-sobre__pilares-inner {
	max-width: 1100px;
	margin: 0 auto;
	text-align: center;
}

.vruumy-sobre__section-kicker {
	font-family: var(--vruumy-font-heading);
	font-size: .6rem;
	font-weight: 700;
	letter-spacing: .32em;
	text-transform: uppercase;
	color: var(--vruumy-blue);
	margin: 0 0 .65rem;
}

.vruumy-sobre__section-title {
	font-family: var(--vruumy-font-heading);
	font-size: clamp(1.5rem, 4vw, 2.4rem);
	font-weight: 900;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--vruumy-white);
	margin: 0 0 3rem;
}

.vruumy-sobre__pilares-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.5rem;
}

.vruumy-sobre__pilar {
	background: linear-gradient(145deg, var(--vruumy-gray), rgba(26,26,35,.5));
	border: 1px solid var(--vruumy-border);
	border-radius: var(--vruumy-radius);
	padding: 2rem 1.5rem;
	text-align: center;
	transition: border-color .28s var(--vruumy-ease), box-shadow .28s var(--vruumy-ease), transform .28s var(--vruumy-ease);
}

.vruumy-sobre__pilar:hover {
	transform: translateY(-6px);
	border-color: rgba(0, 178, 255, .35);
	box-shadow: 0 8px 32px rgba(0, 178, 255, .14);
}

.vruumy-sobre__pilar:nth-child(2n):hover {
	border-color: rgba(255, 45, 142, .35);
	box-shadow: 0 8px 32px rgba(255, 45, 142, .14);
}

.vruumy-sobre__pilar-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 14px;
	margin-bottom: 1.25rem;
}

.vruumy-sobre__pilar-icon--blue {
	background: linear-gradient(135deg, rgba(0,178,255,.16), rgba(0,178,255,.06));
	border: 1px solid rgba(0, 178, 255, .28);
	color: var(--vruumy-blue);
	box-shadow: 0 0 20px rgba(0, 178, 255, .18);
}

.vruumy-sobre__pilar-icon--pink {
	background: linear-gradient(135deg, rgba(255,45,142,.16), rgba(255,45,142,.06));
	border: 1px solid rgba(255, 45, 142, .28);
	color: var(--vruumy-pink);
	box-shadow: 0 0 20px rgba(255, 45, 142, .18);
}

.vruumy-sobre__pilar-icon .vruumy-icon svg { width: 22px; height: 22px; }

.vruumy-sobre__pilar-title {
	font-family: var(--vruumy-font-heading);
	font-size: .78rem;
	font-weight: 700;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: var(--vruumy-white);
	margin: 0 0 .75rem;
}

.vruumy-sobre__pilar-text {
	font-size: .88rem;
	line-height: 1.72;
	color: var(--vruumy-text-muted);
	margin: 0;
}

/* ==========================================================================
   Historia
   ========================================================================== */
.vruumy-sobre__historia {
	padding: clamp(4rem, 9vw, 7rem) clamp(1.25rem, 5vw, 3rem);
	background: linear-gradient(180deg, transparent 0%, rgba(255,45,142,.03) 50%, transparent 100%);
	border-top: 1px solid var(--vruumy-border);
	border-bottom: 1px solid var(--vruumy-border);
}

.vruumy-sobre__historia-inner {
	max-width: 1060px;
	margin: 0 auto;
	display: flex;
	gap: clamp(2.5rem, 6vw, 5rem);
	align-items: center;
}

.vruumy-sobre__historia-visual {
	position: relative;
	width: 160px;
	height: 160px;
	flex-shrink: 0;
}

.vruumy-sobre__historia-ring {
	position: absolute;
	top: 50%;
	left: 50%;
	border-radius: 50%;
}

.vruumy-sobre__historia-ring--1 {
	width: 80px;
	height: 80px;
	background: linear-gradient(135deg, rgba(0,178,255,.18), rgba(255,45,142,.12));
	border: 1px solid rgba(0, 178, 255, .35);
	color: var(--vruumy-blue);
	transform: translate(-50%, -50%);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 0 28px rgba(0, 178, 255, .3);
	z-index: 3;
}

.vruumy-sobre__historia-ring--1 .vruumy-icon svg { width: 28px; height: 28px; }

.vruumy-sobre__historia-ring--2 {
	width: 120px;
	height: 120px;
	transform: translate(-50%, -50%);
	border: 1px dashed rgba(0, 178, 255, .22);
	animation: vruumy-sobre-ring-spin 12s linear infinite;
	z-index: 2;
}

.vruumy-sobre__historia-ring--3 {
	width: 158px;
	height: 158px;
	transform: translate(-50%, -50%);
	border: 1px dashed rgba(255, 45, 142, .18);
	animation: vruumy-sobre-ring-spin-r 18s linear infinite;
	z-index: 1;
}

.vruumy-sobre__historia-content { flex: 1; }

.vruumy-sobre__historia-content .vruumy-sobre__section-kicker { text-align: left; }
.vruumy-sobre__historia-content .vruumy-sobre__section-title {
	text-align: left;
	margin-bottom: 1.25rem;
}

.vruumy-sobre__historia-content p {
	font-size: clamp(.9rem, 1.8vw, 1rem);
	line-height: 1.85;
	color: rgba(210, 210, 230, .88);
	margin: 0 0 1rem;
}

.vruumy-sobre__historia-content p:last-child { margin: 0; }

/* ==========================================================================
   Fechamento
   ========================================================================== */
.vruumy-sobre__fechamento {
	position: relative;
	padding: clamp(5rem, 12vw, 9rem) clamp(1.25rem, 5vw, 3rem);
	text-align: center;
	overflow: hidden;
	isolation: isolate;
}

.vruumy-sobre__fechamento-bg {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse 70% 60% at 30% 50%, rgba(0, 178, 255, .1) 0%, transparent 65%),
		radial-gradient(ellipse 60% 55% at 70% 50%, rgba(255, 45, 142, .1) 0%, transparent 65%);
	pointer-events: none;
	z-index: 0;
}

.vruumy-sobre__fechamento > * { position: relative; z-index: 1; }

.vruumy-sobre__fechamento-inner {
	max-width: 760px;
	margin: 0 auto;
}

.vruumy-sobre__fechamento-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 54px;
	height: 54px;
	border-radius: 50%;
	background: linear-gradient(135deg, rgba(255,45,142,.18), rgba(0,178,255,.12));
	border: 1px solid rgba(255, 45, 142, .35);
	color: var(--vruumy-pink);
	margin-bottom: 2rem;
	box-shadow: 0 0 28px rgba(255, 45, 142, .3);
	animation: vruumy-sobre-pulse-glow 2.5s ease-in-out infinite;
}

.vruumy-sobre__fechamento-icon .vruumy-icon svg { width: 22px; height: 22px; }

.vruumy-sobre__frase {
	margin: 0 0 2rem;
	padding: 0;
	border: none;
	background: none;
	background-color: transparent;
	box-shadow: none;
}

.vruumy-sobre__frase p {
	font-family: var(--vruumy-font-heading);
	font-size: clamp(1.5rem, 5vw, 2.8rem);
	font-weight: 900;
	letter-spacing: .04em;
	line-height: 1.2;
	margin: 0 0 .3rem;
	color: var(--vruumy-white);
}

.vruumy-sobre__frase p:last-child {
	background: var(--vruumy-gradient);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	filter: drop-shadow(0 0 24px rgba(255, 45, 142, .45));
	margin: 0;
}

.vruumy-sobre__fechamento-assinatura {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .3rem;
	margin: 2rem 0 2.5rem;
	font-size: .78rem;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--vruumy-text-muted);
}

.vruumy-sobre__fechamento-logo {
	font-family: var(--vruumy-font-heading);
	font-size: 1.1rem;
	font-weight: 900;
	letter-spacing: .14em;
	background: var(--vruumy-gradient);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.vruumy-sobre__fechamento-dot {
	-webkit-text-fill-color: var(--vruumy-pink);
}

.vruumy-sobre__cta {
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	padding: .85em 2em;
	border-radius: 50px;
	background: var(--vruumy-gradient);
	color: var(--vruumy-white);
	font-family: var(--vruumy-font-heading);
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .18em;
	text-transform: uppercase;
	text-decoration: none;
	box-shadow: 0 4px 24px rgba(0, 178, 255, .35), 0 0 0 1px rgba(0, 178, 255, .2);
	transition: box-shadow .28s var(--vruumy-ease), transform .28s var(--vruumy-ease), opacity .28s var(--vruumy-ease);
}

.vruumy-sobre__cta:hover {
	transform: translateY(-3px) scale(1.03);
	box-shadow: 0 8px 36px rgba(255, 45, 142, .5), 0 0 0 1px rgba(255, 45, 142, .3);
	color: var(--vruumy-white);
}

.vruumy-sobre__cta .vruumy-icon svg { width: 14px; height: 14px; }

/* ==========================================================================
   Responsivo
   ========================================================================== */
@media (max-width: 820px) {
	.vruumy-sobre__manifesto-inner {
		flex-direction: column;
		gap: 1.5rem;
	}
	.vruumy-sobre__manifesto-accent { display: none; }

	.vruumy-sobre__historia-inner {
		flex-direction: column;
		text-align: center;
	}
	.vruumy-sobre__historia-content .vruumy-sobre__section-kicker,
	.vruumy-sobre__historia-content .vruumy-sobre__section-title {
		text-align: center;
	}
	.vruumy-sobre__historia-visual { margin: 0 auto; }
}

@media (max-width: 500px) {
	.vruumy-sobre__pilares-grid {
		grid-template-columns: 1fr;
	}
	.vruumy-sobre__hero-badges {
		flex-direction: column;
		align-items: center;
	}
	.vruumy-sobre__frase p {
		font-size: clamp(1.25rem, 7vw, 1.8rem);
	}
}

@media (max-width: 380px) {
	.vruumy-sobre__title-brand {
		font-size: clamp(3rem, 18vw, 4.5rem);
	}
	.vruumy-sobre__historia-visual {
		width: 120px;
		height: 120px;
	}
	.vruumy-sobre__historia-ring--1 {
		width: 60px;
		height: 60px;
	}
	.vruumy-sobre__historia-ring--2 {
		width: 90px;
		height: 90px;
	}
	.vruumy-sobre__historia-ring--3 {
		width: 118px;
		height: 118px;
	}
}
