

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed,  figure, figcaption, footer, header, hgroup,  menu, nav, output, ruby, section, summary, time, mark, audio, video, button { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; font-synthesis:none; -moz-font-feature-settings: 'kern'; -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased !important; box-sizing:border-box; }

html { }
  
 @font-face {
	   font-family: 'HNV Fallback';
	   src: local('Arial');
	   size-adjust: 95%;
	   ascent-override: 105%;
	   descent-override: 35%;
	   line-gap-override: 0%;
 }

 @font-face {
	   font-family: 'HNV';
	   src: url('fonts/hnv.woff2') format("woff2-variations");
	   font-weight: 400;
	   font-style: normal;
	   font-display: swap;
 }

 :root { --destacado:#f70c7e; --gradiente:linear-gradient(27deg, rgba(0,255,177,0.5) 0%, rgba(0,119,255,0.04) 48%, rgba(225,0,255,0.88) 100%), linear-gradient(121deg, #00cbff 0%, #0032ff 100%); }

html { scroll-behavior: smooth; }
body { font-family: 'HNV', 'HNV Fallback', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif; }

body { max-width:1250px; margin-inline:auto; box-sizing:border-box; padding:0 12px; }

header .cnt { display:flex; justify-content:space-between; margin-top:10px; align-items:center; }
@keyframes pillIn {
	from { opacity:0; transform:translateY(-10px) scale(.92); }
	to   { opacity:1; transform:translateY(0) scale(1); }
}
header .header-actions { display:flex; align-items:center; gap:10px; }
header .btn-login { background:var(--gradiente); padding:7px 22px; border-radius:12px; corner-shape:squircle; color:#FFF; text-decoration:none; font-weight:bold; font-variation-settings:'wght' 750; cursor:pointer; transition:filter .2s, transform .15s; animation:pillIn .5s cubic-bezier(.175,.885,.32,1.275) .15s both; }
header .btn-login:hover { filter:brightness(1.1); transform:translateY(-1px); }
header .lang-switch { display:flex; align-items:center; gap:5px; padding:7px 14px; border-radius:12px; corner-shape:squircle; background:rgba(0,0,0,.05); color:#555; text-decoration:none; font-size:13px; font-weight:bold; font-variation-settings:'wght' 700; letter-spacing:.03em; transition:background .2s, color .2s, transform .15s; animation:pillIn .5s cubic-bezier(.175,.885,.32,1.275) .05s both; }
header .lang-switch:hover { background:rgba(0,0,0,.1); color:#111; transform:translateY(-1px); }
header .lang-switch svg { flex-shrink:0; }
header .logo { width:120px; height:auto; display:flex; align-items:center; }
header .logo svg { width:100%; height:auto; display:block; }

.content { padding-top:100px; }

@keyframes texturePan { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }
h2 { font-size:76px; max-width:80%; padding-bottom:10px; margin-bottom:120px; line-height:.98em; font-variation-settings:'wght' 900; background:url(/images/texture.webp); background-size:200% auto; -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; animation:texturePan 40s ease infinite; }


/* Feature items */
@keyframes featureIn {
	from { opacity:0; transform:translateY(80px) scale(.88); }
	to   { opacity:1; transform:translateY(0) scale(1); }
}
.item { display:flex; margin-bottom:60px; }
@supports (animation-timeline: view()) {
	.item { animation:featureIn linear both; animation-timeline:view(); animation-range:entry 0% entry 100%; }
}
@supports not (animation-timeline: view()) {
	.item { animation:featureIn .65s cubic-bezier(.16,1,.3,1) calc(.1s * var(--i, 0) + .4s) both; }
}
.item .img { flex:0 0 50%; display:flex; align-items:center; justify-content:center; }
.item .img svg { width:88%; max-width:400px; height:auto; }
.item .text {
	flex:0 0 50%; padding:32px 28px;
	border-radius:28px; corner-shape:squircle;
	background:linear-gradient(145deg, rgba(255,255,255,.85), rgba(248,250,252,.6));
	border:1px solid rgba(0,0,0,.08);
	box-shadow:0 1px 3px rgba(0,0,0,.04), 0 8px 24px rgba(0,0,0,.03);
	transition:transform .25s cubic-bezier(.33,1,.68,1), box-shadow .25s ease, border-color .25s ease;
}
.item .text:hover {
	transform:translateY(-4px);
	box-shadow:0 4px 12px rgba(0,0,0,.06), 0 16px 40px rgba(0,0,0,.06);
	border-color:rgba(0,0,0,.12);
}
.feature-icon {
	width:52px; height:52px; border-radius:14px; corner-shape:squircle;
	background:var(--gradiente); color:#fff;
	display:flex; align-items:center; justify-content:center; margin-bottom:18px;
	overflow:hidden;
}
@keyframes uploadArrow {
	0%, 10% { transform:translateY(0); opacity:1; }
	45% { transform:translateY(-24px); opacity:0; }
	46% { transform:translateY(24px); opacity:0; }
	90%, 100% { transform:translateY(0); opacity:1; }
}
.anim-upload { animation:uploadArrow 2.5s ease-in-out infinite; }
@keyframes filmScroll {
	from { transform:translateY(0); }
	to { transform:translateY(-5px); }
}
.anim-film { animation:filmScroll 1.5s linear infinite; }
.item .text h3 { font-size:22px; font-variation-settings:'wght' 700; line-height:1.3em; color:#1a1a1a; margin-bottom:16px; }
.feature-points { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:14px; }
.feature-points li { font-size:14px; line-height:1.55em; color:#444; }
.feature-points li strong { display:block; font-size:16px; font-variation-settings:'wght' 650; color:#1a1a1a; margin-bottom:2px; }

/* Footer */
footer { margin-top:100px; padding:40px 0 32px; border-top:1px solid rgba(0,0,0,.06); }
.footer-cnt { display:flex; justify-content:space-between; align-items:center; }
.footer-brand { display:flex; align-items:center; gap:14px; }
.footer-logo { width:80px; display:block; opacity:.7; transition:opacity .3s; }
.footer-logo:hover { opacity:1; }
.footer-logo svg { width:100%; height:auto; display:block; }
.footer-copy { font-size:12px; color:#aaa; letter-spacing:.02em; }
.footer-nav { display:flex; gap:24px; }
.footer-nav a { font-size:13px; color:#999; text-decoration:none; transition:color .2s; }
.footer-nav a:hover { color:#333; }

/* Legal pages */
.legal-page { padding-top:60px; }
.legal-page h2 { font-size:36px; max-width:100%; margin-bottom:12px; background:none; -webkit-text-fill-color:#1a1a1a; color:#1a1a1a; animation:none; }
.legal-page .legal-updated { font-size:14px; color:#888; margin-bottom:48px; }
.legal-page h3 { font-size:20px; font-variation-settings:'wght' 700; color:#1a1a1a; margin-top:36px; margin-bottom:12px; }
.legal-page h4 { font-size:16px; font-variation-settings:'wght' 650; color:#333; margin-top:24px; margin-bottom:8px; }
.legal-page p { font-size:15px; line-height:1.7em; color:#444; margin-bottom:12px; max-width:780px; }
.legal-page ul { list-style:disc; padding-left:24px; margin-bottom:16px; max-width:780px; }
.legal-page ul li { font-size:15px; line-height:1.7em; color:#444; margin-bottom:6px; }

/* Tablet */
@media (max-width:768px) {
	.content { padding-top:60px; }
	h2 { font-size:48px; max-width:100%; margin-bottom:60px; }
	.item .img { flex:0 0 40%; }
	.item .img svg { width:100%; }
	.item .text { padding:24px 22px; }
	.item .text h3 { font-size:20px; }
	footer { margin-top:60px; }
}

/* Mobile */
@media (max-width:560px) {
	.content { padding-top:40px; }
	h2 { font-size:34px; max-width:100%; margin-bottom:36px; line-height:1.08em; }
	.item { flex-direction:column; margin-bottom:32px; }
	.item .img { flex:0 0 auto; margin-bottom:12px; }
	.item .img svg { width:70%; max-width:260px; margin:0 auto; display:block; }
	.item .text { flex:1; padding:22px 18px; border-radius:20px; }
	.item .text h3 { font-size:19px; margin-bottom:12px; }
	.feature-icon { width:44px; height:44px; border-radius:12px; margin-bottom:14px; }
	.feature-icon svg { width:24px; height:24px; }
	.feature-points { gap:12px; }
	.feature-points li { font-size:13.5px; }
	.feature-points li strong { font-size:15px; }
	header .cnt { margin-top:6px; }
	header .logo { width:100px; }
	header .btn-login { padding:7px 16px; font-size:14px; }
	header .lang-switch { padding:7px 10px; font-size:12px; }
	footer { margin-top:40px; padding:28px 0 24px; }
	.footer-cnt { flex-direction:column; gap:16px; align-items:center; text-align:center; }
	.footer-brand { flex-direction:column; gap:8px; align-items:center; }
	.footer-nav { gap:16px; flex-wrap:wrap; justify-content:center; }
	.legal-page { padding-top:40px; }
	.legal-page h2 { font-size:26px; }
	.legal-page p, .legal-page ul li { font-size:14px; }
}