:root {
  --ink: #0a1728;
  --navy: #08111f;
  --navy-2: #0d1b2f;
  --blue: #2864f0;
  --blue-dark: #174ac0;
  --cyan: #43d5c5;
  --paper: #f6f8fb;
  --white: #ffffff;
  --muted: #5e6b7c;
  --line: #dce3ec;
  --font: Inter, Avenir, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

html { font-size: 16px; scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--white); font-family: var(--font); -webkit-font-smoothing: antialiased; }
body, button, input, textarea { font-family: var(--font); }
a { color: inherit; text-decoration: none; }
p { line-height: 1.75; }
img,svg,video { max-width: 100%; height: auto; }
main { min-width: 0; }
.site-container { max-width: 1200px; }
.skip-link { position: fixed; top: -100px; left: 1rem; z-index: 1100; padding: .75rem 1rem; color: white; background: var(--blue); border-radius: 0 0 .5rem .5rem; }
.skip-link:focus { top: 0; }

.social-rail { position: fixed; top: 50%; left: 0; z-index: 990; display: flex; flex-direction: column; overflow: hidden; background: white; border: 1px solid rgba(10,23,40,.12); border-left: 0; border-radius: 0 10px 10px 0; box-shadow: 0 12px 34px rgba(8,17,31,.16); transform: translateY(-50%); }
.social-link { display: grid; width: 46px; height: 46px; place-items: center; color: #536176; border-bottom: 1px solid var(--line); transition: color .2s ease, background-color .2s ease, transform .2s ease; }
.social-link:last-child { border-bottom: 0; }
.social-link svg { width: 21px; height: 21px; fill: currentColor; }
.social-link:hover, .social-link:focus-visible { color: white; outline: 0; transform: translateX(2px); }
.social-link:focus-visible { box-shadow: inset 0 0 0 3px rgba(255,255,255,.7); }
.social-facebook:hover, .social-facebook:focus-visible { background: #1877f2; }
.social-instagram:hover, .social-instagram:focus-visible { background: #c13584; }
.social-whatsapp:hover, .social-whatsapp:focus-visible { background: #25d366; }
.social-telegram:hover, .social-telegram:focus-visible { background: #229ed9; }
.social-linkedin:hover, .social-linkedin:focus-visible { background: #0a66c2; }
.social-youtube:hover, .social-youtube:focus-visible { background: #ff0000; }

.site-header { position: sticky; top: 0; z-index: 1000; background: rgba(255,255,255,.92); border-bottom: 1px solid rgba(10,23,40,.08); backdrop-filter: blur(16px); }
.navbar { min-height: 78px; padding: .8rem 0; }
.brand { display: inline-flex; align-items: center; gap: .7rem; padding: 0; }
.brand-mark { display: grid; width: 42px; height: 42px; place-items: center; color: white; background: var(--blue); border-radius: 10px; font-size: .82rem; font-weight: 800; letter-spacing: -.04em; box-shadow: 0 8px 24px rgba(40,100,240,.24); }
.brand-copy { display: flex; flex-direction: column; color: var(--ink); line-height: .98; }
.brand-copy strong { font-size: 1rem; letter-spacing: -.025em; }
.brand-copy span { margin-top: .2rem; color: var(--muted); font-size: .66rem; font-weight: 700; letter-spacing: .17em; text-transform: uppercase; }
.navbar-nav { align-items: center; gap: .35rem; }
.navbar .nav-link { position: relative; padding: .7rem .75rem !important; color: #39475a; font-size: .91rem; font-weight: 600; }
.navbar .nav-link::after { position: absolute; right: .75rem; bottom: .35rem; left: .75rem; height: 2px; content: ""; background: var(--blue); transform: scaleX(0); transition: transform .2s ease; }
.navbar .nav-link:hover, .navbar .nav-link:focus { color: var(--blue); }
.navbar .nav-link:hover::after, .navbar .nav-link:focus::after { transform: scaleX(1); }
.navbar .nav-link.active { color: var(--blue); }
.navbar .nav-link.active::after { transform: scaleX(1); }
.nav-actions, .account-nav { display: flex; align-items: center; gap: 1rem; }
.account-nav form { margin: 0; }
.account-link { display: inline-flex; min-height: 44px; align-items: center; color: #39475a; font-size: .88rem; font-weight: 650; white-space: nowrap; }
.account-link:hover { color: var(--blue); }
.account-button { padding: 0; border: 0; background: none; }
.navbar-toggler { width: 42px; height: 38px; padding: 8px; border: 1px solid var(--line); border-radius: 8px; }
.navbar-toggler span { display: block; width: 100%; height: 2px; margin: 4px 0; background: var(--ink); }
.navbar-toggler:focus { box-shadow: 0 0 0 3px rgba(40,100,240,.18); }

.button { display: inline-flex; align-items: center; justify-content: center; gap: .75rem; min-height: 50px; padding: .85rem 1.35rem; border: 1px solid transparent; border-radius: 8px; font-size: .9rem; font-weight: 750; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.button:hover { transform: translateY(-2px); }
.button-primary { color: white; background: var(--blue); box-shadow: 0 10px 28px rgba(40,100,240,.24); }
.button-primary:hover { color: white; background: var(--blue-dark); box-shadow: 0 14px 34px rgba(40,100,240,.3); }
.button-secondary { color: var(--ink); background: white; border-color: var(--line); }
.button-secondary:hover { color: var(--blue); border-color: #aabce8; }
.button-light { color: var(--ink); background: white; }
.button-light:hover { color: var(--blue); }
.button-sm { min-height: 42px; padding: .65rem 1rem; font-size: .82rem; }

.hero { position: relative; min-height: 680px; overflow: hidden; background: linear-gradient(140deg,#f9fbff 0%,#f3f7ff 55%,#eef3fb 100%); }
.hero::before { position: absolute; inset: 0; content: ""; opacity: .38; background-image: linear-gradient(rgba(31,74,139,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(31,74,139,.07) 1px,transparent 1px); background-size: 54px 54px; mask-image: linear-gradient(90deg,transparent 0%,black 58%,black 100%); }
.hero-glow { position: absolute; border-radius: 50%; filter: blur(2px); pointer-events: none; }
.hero-glow-one { top: 10%; right: -8%; width: 500px; height: 500px; background: radial-gradient(circle,rgba(51,114,255,.17),transparent 68%); }
.hero-glow-two { bottom: -30%; left: -10%; width: 430px; height: 430px; background: radial-gradient(circle,rgba(67,213,197,.12),transparent 68%); }
.hero-grid { position: relative; display: grid; grid-template-columns: 1.05fr .95fr; align-items: center; min-height: 680px; gap: 4rem; padding-top: 4rem; padding-bottom: 4rem; }
.eyebrow { display: flex; align-items: center; gap: .65rem; color: var(--blue); font-size: .7rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.eyebrow > span { width: 24px; height: 2px; background: currentColor; }
.eyebrow.light { color: #8caeff; }
.hero h1 { max-width: 720px; margin: 1.25rem 0 1.35rem; font-size: clamp(3rem,5.2vw,5.1rem); font-weight: 760; line-height: .98; letter-spacing: -.062em; }
.hero h1 em { color: var(--blue); font-style: normal; }
.hero-lead { max-width: 660px; margin: 0; color: var(--muted); font-size: 1.07rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 2rem; }
.hero-proof { display: flex; align-items: stretch; gap: 0; margin-top: 2.7rem; }
.hero-proof div { display: flex; flex-direction: column; justify-content: center; min-width: 145px; padding: 0 1.35rem; border-left: 1px solid var(--line); }
.hero-proof div:first-child { padding-left: 0; border-left: 0; }
.hero-proof strong { font-size: .9rem; }
.hero-proof span { margin-top: .2rem; color: var(--muted); font-size: .68rem; }

.hero-visual { position: relative; min-height: 480px; perspective: 1200px; }
.visual-orbit { position: absolute; border: 1px solid rgba(40,100,240,.14); border-radius: 50%; }
.orbit-one { inset: 5% 2% 6% 8%; }
.orbit-two { inset: 19% 15% 20% 20%; border-color: rgba(67,213,197,.2); }
.visual-card { border: 1px solid rgba(255,255,255,.8); background: rgba(255,255,255,.92); box-shadow: 0 24px 70px rgba(24,52,97,.15); backdrop-filter: blur(14px); }
.main-card { position: absolute; top: 14%; right: 3%; left: 9%; padding: 1.35rem; border-radius: 18px; transform: rotateY(-5deg) rotateX(2deg); }
.visual-card-top { display: flex; align-items: center; gap: .55rem; padding-bottom: 1rem; color: var(--muted); border-bottom: 1px solid var(--line); font-size: .72rem; font-weight: 700; }
.status-dot { width: 7px; height: 7px; background: var(--cyan); border-radius: 50%; box-shadow: 0 0 0 5px rgba(67,213,197,.13); }
.status-label { margin-left: auto; padding: .35rem .55rem; color: #087f72; background: #e4faf7; border-radius: 100px; font-size: .6rem; text-transform: uppercase; }
.security-score { display: flex; align-items: center; gap: 1rem; padding: 1.4rem 0; }
.score-ring { display: flex; align-items: baseline; justify-content: center; width: 94px; height: 94px; padding-top: 27px; border: 8px solid #dfe8fb; border-top-color: var(--blue); border-right-color: var(--cyan); border-radius: 50%; transform: rotate(-12deg); }
.score-ring span, .score-ring small { transform: rotate(12deg); }
.score-ring span { font-size: 1.5rem; font-weight: 800; }
.score-ring small { color: var(--muted); font-size: .58rem; }
.security-score > div:last-child { display: flex; flex-direction: column; }
.security-score small { color: var(--muted); font-size: .67rem; }
.security-score strong { margin-top: .2rem; font-size: 1rem; }
.code-lines { display: grid; gap: .55rem; padding: 1rem; background: var(--navy); border-radius: 10px; }
.code-lines span { width: var(--line-width); height: 5px; background: linear-gradient(90deg,var(--cyan),rgba(67,213,197,.1)); border-radius: 4px; }
.system-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-top: .9rem; }
.system-metrics div { display: flex; align-items: center; justify-content: space-between; padding: .7rem; background: var(--paper); border-radius: 8px; }
.system-metrics span { color: var(--muted); font-size: .63rem; }
.system-metrics strong { font-size: .75rem; }
.floating-card { position: absolute; z-index: 2; display: flex; align-items: center; gap: .75rem; padding: .8rem 1rem; border-radius: 12px; animation: float 5s ease-in-out infinite; }
.floating-card div { display: flex; flex-direction: column; }
.floating-card strong { font-size: .72rem; }.floating-card small { color: var(--muted); font-size: .58rem; }
.floating-icon { display: grid; width: 35px; height: 35px; place-items: center; color: var(--blue); background: #eaf0ff; border-radius: 8px; font-size: .68rem; font-weight: 900; }
.card-code { top: 6%; left: -2%; }.card-shield { right: -4%; bottom: 7%; animation-delay: -2.5s; }.card-shield .floating-icon { color: #087f72; background: #e4faf7; }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-9px); } }

.trust-strip { color: white; background: var(--navy); }
.trust-slider { min-height: 76px; overflow: hidden; outline: none; }
.trust-slider:focus-visible { box-shadow: inset 0 0 0 2px var(--cyan); }
.trust-track { display: flex; width: max-content; min-height: 76px; animation: trust-scroll 48s linear infinite; will-change: transform; }
.trust-group { display: flex; flex-shrink: 0; align-items: center; gap: 2.5rem; padding-right: 2.5rem; }
.trust-group span { color: #bec9d8; font-size: .69rem; font-weight: 700; letter-spacing: .11em; text-transform: uppercase; white-space: nowrap; }
.trust-group i { flex: 0 0 4px; width: 4px; height: 4px; background: var(--cyan); border-radius: 50%; }
.trust-slider:hover .trust-track, .trust-slider:focus .trust-track, .trust-slider:focus-within .trust-track { animation-play-state: paused; }
@keyframes trust-scroll { to { transform: translateX(-50%); } }
.section { padding: 7rem 0; }
.section-heading { display: grid; grid-template-columns: 1.2fr .8fr; align-items: end; gap: 4rem; margin-bottom: 3.3rem; }
.section-heading h2, .about-copy h2 { margin: .9rem 0 0; font-size: clamp(2.2rem,4vw,3.55rem); font-weight: 750; line-height: 1.06; letter-spacing: -.048em; }
.section-heading > p { max-width: 470px; margin: 0; color: var(--muted); font-size: .96rem; }
.section-heading.compact { display: block; max-width: 720px; }

.services-section { background: white; }
.service-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.15rem; }
.service-card { position: relative; display: flex; flex-direction: column; min-height: 510px; padding: 2rem; overflow: hidden; border: 1px solid var(--line); border-radius: 14px; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.service-card:hover { transform: translateY(-6px); border-color: #b8c8ed; box-shadow: 0 24px 50px rgba(18,44,83,.1); }
.service-card-featured { border-color: #d2ddf6; background: linear-gradient(145deg,#fbfcff,#f4f7ff); }
.service-number { position: absolute; top: 1.6rem; right: 1.7rem; color: #cbd3df; font-size: .7rem; font-weight: 800; }
.service-icon { display: grid; width: 52px; height: 52px; place-items: center; color: var(--blue); background: #eaf0ff; border-radius: 12px; font-size: .8rem; font-weight: 900; }
.service-card h3 { margin: 1.7rem 0 .8rem; font-size: 1.45rem; font-weight: 750; letter-spacing: -.035em; }
.service-card p { min-height: 84px; color: var(--muted); font-size: .87rem; }
.service-card ul { display: grid; gap: .7rem; margin: .8rem 0 1.8rem; padding: 0; list-style: none; }
.service-card li { position: relative; padding-left: 1.25rem; color: #344256; font-size: .78rem; font-weight: 600; }
.service-card li::before { position: absolute; left: 0; color: var(--blue); content: "✓"; font-weight: 900; }
.service-card > a { display: flex; justify-content: space-between; margin-top: auto; padding-top: 1.1rem; color: var(--blue); border-top: 1px solid var(--line); font-size: .78rem; font-weight: 800; }

.work-section { color: white; background: var(--navy); }
.work-section .section-heading > p { color: #aab8ca; }
.project-grid { display: grid; grid-template-columns: 1.55fr .75fr; gap: 1.2rem; }
.project-card { overflow: hidden; color: var(--ink); background: white; border: 1px solid rgba(255,255,255,.1); border-radius: 16px; transition: transform .25s ease; }
.project-card:hover { transform: translateY(-5px); }
.project-visual { position: relative; height: 260px; overflow: hidden; }
.project-card-large .project-visual { height: 320px; }
.portal-visual { display: grid; place-items: center; background: linear-gradient(135deg,#1849b9,#3982ff); }
.portal-visual::before { position: absolute; inset: 0; content: ""; background-image: radial-gradient(rgba(255,255,255,.18) 1px,transparent 1px); background-size: 18px 18px; }
.mock-window { position: relative; width: 72%; height: 72%; overflow: hidden; background: white; border-radius: 10px; box-shadow: 0 28px 45px rgba(0,15,60,.28); transform: perspective(700px) rotateY(-7deg) rotateX(3deg); }
.mock-bar { display: flex; align-items: center; gap: 4px; height: 12%; padding-left: 4%; background: #eef2f7; }
.mock-bar i { width: 5px; height: 5px; background: #b4c0ce; border-radius: 50%; }
.mock-layout { display: grid; grid-template-columns: 20% 80%; height: 88%; }.mock-sidebar { background: #0d1b2f; }.mock-content { padding: 8%; }.mock-content > span { display: block; width: 80%; height: 7px; margin-bottom: 7px; background: #dce5f4; border-radius: 5px; }.mock-content > span:nth-child(2) { width: 45%; }.mock-panels { display: grid; grid-template-columns: repeat(3,1fr); gap: 5%; margin-top: 15%; }.mock-panels i { height: 60px; background: #edf3ff; border-radius: 5px; }
.security-visual { display: grid; place-items: center; background: linear-gradient(135deg,#10243f,#0b182b); }
.security-visual::after { position: absolute; inset: 0; content: ""; background-image: linear-gradient(rgba(67,213,197,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(67,213,197,.06) 1px,transparent 1px); background-size: 24px 24px; }
.radar { position: relative; z-index: 1; width: 150px; height: 150px; border: 1px solid rgba(67,213,197,.3); border-radius: 50%; box-shadow: inset 0 0 40px rgba(67,213,197,.08),0 0 30px rgba(67,213,197,.1); }
.radar::before,.radar::after { position: absolute; content: ""; background: rgba(67,213,197,.25); }.radar::before { top: 50%; left: 0; width: 100%; height: 1px; }.radar::after { top: 0; left: 50%; width: 1px; height: 100%; }.radar span { position: absolute; inset: 22%; border: 1px solid rgba(67,213,197,.23); border-radius: 50%; }.radar i { position: absolute; top: 25%; left: 67%; width: 8px; height: 8px; background: var(--cyan); border-radius: 50%; box-shadow: 0 0 15px var(--cyan); }.radar b { position: absolute; top: 50%; left: 50%; width: 50%; height: 1px; background: linear-gradient(90deg,var(--cyan),transparent); transform-origin: left; transform: rotate(-35deg); }
.project-info { padding: 1.7rem; }.project-type { color: var(--blue); font-size: .65rem; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; }.project-info h3 { margin: .5rem 0 .6rem; font-size: 1.45rem; font-weight: 750; letter-spacing: -.035em; }.project-info p { margin: 0; color: var(--muted); font-size: .82rem; }.tag-list { display: flex; flex-wrap: wrap; gap: .45rem; margin-top: 1rem; }.tag-list span { padding: .35rem .55rem; color: #4c5e77; background: var(--paper); border-radius: 5px; font-size: .6rem; font-weight: 700; }.work-note { margin: 1.2rem 0 0; color: #8493a7; font-size: .7rem; }

.about-section { background: var(--paper); }
.about-grid { display: grid; grid-template-columns: .9fr 1.1fr; align-items: center; gap: 7rem; }
.about-panel { position: relative; min-height: 480px; overflow: hidden; background: linear-gradient(145deg,#132846,#08111f); border-radius: 18px; }
.about-panel::before { position: absolute; inset: 0; content: ""; background-image: linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px); background-size: 38px 38px; }
.binary-panel::after { position: absolute; inset: 0; content: ""; background: linear-gradient(90deg,transparent,rgba(67,213,197,.05),transparent); transform: translateX(-100%); animation: binary-scan 5s ease-in-out infinite; }
.binary-glow { position: absolute; top: 50%; left: 50%; width: 260px; height: 260px; background: radial-gradient(circle,rgba(40,100,240,.28),rgba(67,213,197,.08) 42%,transparent 70%); border-radius: 50%; transform: translate(-50%,-50%); animation: binary-pulse 4s ease-in-out infinite; }
.binary-streams { position: absolute; inset: -8% 0; display: flex; flex-direction: column; justify-content: space-around; overflow: hidden; transform: rotate(-8deg) scale(1.12); }
.binary-streams span { display: block; color: rgba(99,230,214,.24); font-family: "Cascadia Code",Consolas,monospace; font-size: .67rem; font-weight: 600; letter-spacing: .24em; white-space: nowrap; text-shadow: 0 0 12px rgba(67,213,197,.35); animation: binary-drift 12s linear infinite; }
.binary-streams span:nth-child(even) { color: rgba(111,151,255,.2); animation-direction: reverse; animation-duration: 15s; }
.binary-streams span:nth-child(3n) { animation-duration: 18s; }
.binary-core { position: absolute; top: 50%; left: 50%; z-index: 2; display: grid; width: 132px; height: 132px; place-items: center; color: white; background: rgba(8,17,31,.78); border: 1px solid rgba(67,213,197,.5); border-radius: 50%; box-shadow: 0 0 0 14px rgba(67,213,197,.035),0 0 50px rgba(40,100,240,.28),inset 0 0 28px rgba(67,213,197,.08); transform: translate(-50%,-50%); }
.binary-core span { font-size: 2.3rem; font-weight: 850; letter-spacing: -.1em; }
.binary-core i,.binary-core b { position: absolute; inset: -22px; border: 1px solid rgba(67,213,197,.16); border-radius: 50%; animation: binary-orbit 12s linear infinite; }
.binary-core b { inset: -48px; border-color: rgba(83,126,244,.13); animation-direction: reverse; animation-duration: 18s; }
.binary-core i::after,.binary-core b::after { position: absolute; top: 50%; right: -3px; width: 6px; height: 6px; content: ""; background: var(--cyan); border-radius: 50%; box-shadow: 0 0 12px var(--cyan); }
.binary-core b::after { top: 18%; right: 12%; background: #6d91ff; box-shadow: 0 0 12px #6d91ff; }
.binary-status { position: absolute; right: 1.2rem; bottom: 1.1rem; z-index: 3; display: flex; align-items: center; gap: .5rem; padding: .55rem .75rem; color: #b8c8d9; background: rgba(5,13,25,.7); border: 1px solid rgba(255,255,255,.08); border-radius: 100px; font-size: .56rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; backdrop-filter: blur(8px); }
.binary-status i { width: 6px; height: 6px; background: var(--cyan); border-radius: 50%; box-shadow: 0 0 9px var(--cyan); animation: binary-pulse 2s ease-in-out infinite; }
@keyframes binary-drift { from { transform: translateX(-16%); } to { transform: translateX(16%); } }
@keyframes binary-orbit { to { transform: rotate(360deg); } }
@keyframes binary-pulse { 0%,100% { opacity: .65; } 50% { opacity: 1; } }
@keyframes binary-scan { 0%,20% { transform: translateX(-100%); } 70%,100% { transform: translateX(100%); } }
.about-copy > p { margin: 1.5rem 0 2rem; color: var(--muted); }.principles { display: grid; gap: 1rem; }.principles > div { display: grid; grid-template-columns: 42px 1fr; gap: .8rem; padding-top: 1rem; border-top: 1px solid var(--line); }.principles span { color: var(--blue); font-size: .68rem; font-weight: 800; }.principles p { display: flex; flex-direction: column; margin: 0; color: var(--muted); font-size: .77rem; line-height: 1.5; }.principles strong { margin-bottom: .22rem; color: var(--ink); font-size: .88rem; }

.process-section { background: white; }
.process-grid { position: relative; display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; }
.process-grid::before { position: absolute; top: 23px; right: 10%; left: 10%; height: 1px; content: ""; background: var(--line); }
.process-grid article { position: relative; padding: 0 1.2rem; text-align: center; }.process-grid article > span { position: relative; z-index: 1; display: grid; width: 46px; height: 46px; margin: 0 auto 1.3rem; place-items: center; color: var(--blue); background: white; border: 1px solid #bfcdf0; border-radius: 50%; font-size: .66rem; font-weight: 800; }.process-grid h3 { font-size: 1.02rem; font-weight: 750; }.process-grid p { color: var(--muted); font-size: .76rem; }
.contact-section { position: relative; overflow: hidden; color: white; background: linear-gradient(135deg,#245de0 0%,#1748bd 48%,#0b2454 100%); }
.contact-section::before { position: absolute; top: -280px; right: -180px; width: 620px; height: 620px; content: ""; background: radial-gradient(circle,rgba(67,213,197,.22),transparent 68%); border-radius: 50%; }
.contact-grid-pattern { position: absolute; inset: 0; opacity: .12; background-image: linear-gradient(white 1px,transparent 1px),linear-gradient(90deg,white 1px,transparent 1px); background-size: 48px 48px; mask-image: linear-gradient(90deg,transparent,black); }
.contact-inner { position: relative; display: grid; grid-template-columns: .82fr 1.18fr; align-items: center; gap: 5rem; min-height: 720px; padding-top: 6rem; padding-bottom: 6rem; }
.contact-inner h2 { max-width: 520px; margin: .8rem 0; font-size: clamp(2.7rem,4.2vw,4.3rem); font-weight: 760; line-height: 1; letter-spacing: -.055em; }
.contact-copy > p { max-width: 540px; margin: 0; color: #dce6ff; }
.contact-points { display: grid; gap: 1rem; margin: 2.3rem 0; }
.contact-points > div { display: grid; grid-template-columns: 32px 1fr; gap: .8rem; align-items: start; }
.contact-points > div > span { display: grid; width: 28px; height: 28px; place-items: center; color: #7dfff0; background: rgba(67,213,197,.1); border: 1px solid rgba(67,213,197,.28); border-radius: 50%; font-size: .55rem; font-weight: 800; }
.contact-points p { display: flex; flex-direction: column; color: #bfcff0; font-size: .72rem; line-height: 1.45; }
.contact-points strong { margin-bottom: .15rem; color: white; font-size: .82rem; }
.contact-email-link { display: inline-flex; align-items: center; gap: .55rem; color: white; font-size: .78rem; font-weight: 700; }
.contact-email-link,.footer-email { max-width: 100%; overflow-wrap: anywhere; }
.contact-email-link span { display: grid; width: 26px; height: 26px; place-items: center; color: var(--cyan); background: rgba(8,17,31,.25); border-radius: 6px; font-size: .64rem; }
.contact-form { position: relative; padding: 2rem; color: var(--ink); background: linear-gradient(145deg,rgba(255,255,255,.98),rgba(241,246,255,.96)); border: 1px solid rgba(255,255,255,.52); border-radius: 20px; box-shadow: 0 30px 80px rgba(3,18,55,.34),inset 0 1px 0 white; backdrop-filter: blur(18px); }
.contact-form::before { position: absolute; top: 0; right: 12%; left: 12%; height: 3px; content: ""; background: linear-gradient(90deg,transparent,var(--blue),var(--cyan),transparent); border-radius: 0 0 4px 4px; }
.form-heading { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.6rem; padding-bottom: 1.3rem; border-bottom: 1px solid var(--line); }
.form-heading > div { display: flex; flex-direction: column; }
.form-heading span { color: var(--blue); font-size: .6rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.form-heading h3 { margin: .3rem 0 0; font-size: 1.35rem; font-weight: 760; letter-spacing: -.035em; }
.form-heading i { width: 11px; height: 11px; background: var(--cyan); border: 3px solid #d8faf6; border-radius: 50%; box-shadow: 0 0 16px rgba(67,213,197,.8); }
.contact-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.field-group { display: flex; flex-direction: column; gap: .45rem; }
.field-group.field-full { grid-column: 1 / -1; }
.field-group label { color: #26364d; font-size: .68rem; font-weight: 750; }
.field-group label span { color: #8793a3; font-size: .58rem; font-weight: 600; }
.field-group input,.field-group select,.field-group textarea { width: 100%; padding: .8rem .9rem; color: var(--ink); background: rgba(255,255,255,.86); border: 1px solid #d8e0eb; border-radius: 8px; outline: none; font-size: .78rem; transition: border-color .2s ease,box-shadow .2s ease,background .2s ease; }
.field-group,.contact-form-grid > *,.hero-grid > *,.about-grid > *,.section-heading > *,.project-grid > * { min-width: 0; }
.field-group input,.field-group select { height: 46px; }
.field-group textarea { min-height: 122px; resize: vertical; }
.field-group input::placeholder,.field-group textarea::placeholder { color: #9aa6b5; }
.field-group input:hover,.field-group select:hover,.field-group textarea:hover { border-color: #b9c6d8; }
.field-group input:focus,.field-group select:focus,.field-group textarea:focus { background: white; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(40,100,240,.12); }
.consent-field { display: flex; align-items: flex-start; gap: .55rem; margin: 1rem 0; color: #657386; font-size: .64rem; line-height: 1.45; cursor: pointer; }
.consent-field input { width: 15px; height: 15px; margin-top: 1px; accent-color: var(--blue); }
.form-submit-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.contact-submit { min-width: 160px; color: white; background: linear-gradient(110deg,var(--blue),#1851cd 58%,#137d99); border: 0; box-shadow: 0 10px 24px rgba(40,100,240,.25); }
.contact-submit:hover { color: white; box-shadow: 0 14px 30px rgba(40,100,240,.32); }
.form-privacy { color: #7c8897; font-size: .58rem; }
.form-status { min-height: 1.2rem; margin: .6rem 0 0 !important; color: #167467 !important; font-size: .66rem; font-weight: 700; line-height: 1.4; }

.content-page { min-height: calc(100vh - 78px); padding: clamp(4rem,8vw,7rem) 0; background: linear-gradient(145deg,#f8faff,#f1f5fb); }
.content-page h1 { margin: .45rem 0 .75rem; font-size: clamp(2.1rem,5vw,3.5rem); font-weight: 760; line-height: 1.05; letter-spacing: -.05em; }
.page-eyebrow { color: var(--blue); font-size: .65rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.page-intro,.page-heading > p { max-width: 640px; margin: 0 0 2rem; color: var(--muted); font-size: .9rem; }
.auth-page { display: flex; align-items: center; }
.auth-card { width: min(100%,520px); margin: 0 auto; padding: clamp(1.5rem,4vw,2.5rem); background: white; border: 1px solid var(--line); border-radius: 18px; box-shadow: 0 24px 60px rgba(18,44,83,.1); }
.auth-card-wide { width: min(100%,620px); }
.auth-card form,.profile-form-card form { min-width: 0; }
.auth-card .form-control,.profile-form-card .form-control { min-height: 46px; font-size: max(16px,.85rem); }
.auth-card .form-label,.profile-form-card .form-label { color: #26364d; font-size: .75rem; font-weight: 700; }
.auth-card .text-danger,.profile-form-card .text-danger { display: block; margin-top: .25rem; font-size: .7rem; overflow-wrap: anywhere; }
.form-actions { display: flex; align-items: center; gap: 1rem; margin-top: 1.2rem; }
.text-action { padding: .7rem .25rem; color: var(--blue); font-size: .78rem; font-weight: 750; }
.text-action:hover { color: var(--blue-dark); }
.profile-layout { max-width: 900px; margin: 0 auto; }
.profile-form-card { padding: clamp(1.5rem,4vw,2.75rem); background: white; border: 1px solid var(--line); border-radius: 18px; box-shadow: 0 24px 60px rgba(18,44,83,.08); }
.profile-picture { display: block; width: 180px; height: 180px; margin-bottom: 1.5rem; object-fit: cover; border: 5px solid white; border-radius: 16px; box-shadow: 0 10px 28px rgba(10,23,40,.14); }
.form-control[type="file"] { height: auto; min-height: 46px; }
.page-heading { margin-bottom: 2.5rem; }
.dashboard-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 1rem; }
.dashboard-card { display: flex; flex-direction: column; min-height: 260px; padding: 2rem; background: white; border: 1px solid var(--line); border-radius: 14px; box-shadow: 0 14px 35px rgba(18,44,83,.06); }
.dashboard-card > span { color: var(--blue); font-size: .62rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.dashboard-card h2 { margin: 1.1rem 0 .7rem; font-size: 1.35rem; font-weight: 750; letter-spacing: -.03em; }
.dashboard-card p { color: var(--muted); font-size: .8rem; }
.dashboard-card > a { display: flex; justify-content: space-between; margin-top: auto; padding-top: 1rem; color: var(--blue); border-top: 1px solid var(--line); font-size: .78rem; font-weight: 800; }
.dashboard-card-muted { background: linear-gradient(145deg,#0d1b2f,#132846); border-color: transparent; }
.dashboard-card-muted h2 { color: white; }.dashboard-card-muted p { color: #aebdd0; }
.legal-content { max-width: 780px; }
.legal-notice { margin-top: 2rem; padding: 1.4rem; background: #fff8e8; border: 1px solid #ead9a8; border-radius: 10px; }
.legal-notice strong { color: #72550a; font-size: .82rem; }.legal-notice p { margin: .35rem 0 0; color: #746334; font-size: .78rem; }
.state-page { display: flex; align-items: center; }
.state-card { width: min(100%,650px); margin: 0 auto; padding: clamp(1.75rem,5vw,3.5rem); text-align: center; background: white; border: 1px solid var(--line); border-radius: 18px; box-shadow: 0 24px 60px rgba(18,44,83,.1); }
.state-code { display: inline-block; color: #c33b4a; font-size: .68rem; font-weight: 850; letter-spacing: .16em; text-transform: uppercase; }
.state-card p { max-width: 520px; margin: 0 auto 1.5rem; color: var(--muted); }
.request-id { padding: .8rem; background: var(--paper); border-radius: 8px; overflow-wrap: anywhere; }
.request-id code { white-space: normal; overflow-wrap: anywhere; }

.site-footer { padding: 4.5rem 0 1.5rem; color: #9aa9ba; background: var(--navy); }
.footer-grid { display: grid; grid-template-columns: 1.5fr .7fr .9fr 1.25fr; gap: 3rem; }.footer-grid > * { min-width: 0; }.footer-brand .brand-copy { color: white; }.footer-grid > div:first-child p { max-width: 275px; margin-top: 1.3rem; font-size: .76rem; }.footer-grid h2 { margin: 0 0 1.1rem; color: white; font-size: .72rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }.footer-grid > div:not(:first-child) { display: flex; flex-direction: column; align-items: flex-start; }.footer-grid a { margin-bottom: .7rem; font-size: .73rem; }.footer-grid a:hover { color: white; }.footer-grid p { margin: 0 0 .8rem; font-size: .73rem; }.footer-email { color: var(--cyan); }.footer-bottom { display: flex; justify-content: space-between; margin-top: 3.5rem; padding-top: 1.4rem; border-top: 1px solid rgba(255,255,255,.09); font-size: .66rem; }.footer-bottom div { display: flex; gap: 1.2rem; }

.reveal { opacity: 0; transform: translateY(16px); transition: opacity .65s ease, transform .65s ease; }.reveal.revealed { opacity: 1; transform: none; }.reveal-delay { transition-delay: .12s; }
.form-control:focus, .form-check-input:focus { border-color: var(--blue); box-shadow: 0 0 0 .2rem rgba(40,100,240,.15); }

@media (max-width: 1199.98px) {
  .navbar-collapse { padding: 1rem 0 .4rem; border-top: 1px solid var(--line); }.navbar-nav { align-items: stretch; }.navbar .nav-link { display: flex; min-height: 44px; align-items: center; padding: .65rem 0 !important; }.navbar .nav-link::after { display: none; }.navbar .nav-link.active { padding-left: .75rem !important; background: #edf3ff; border-left: 3px solid var(--blue); border-radius: 0 6px 6px 0; }.nav-actions { justify-content: space-between; margin-top: .7rem; }.hero-grid { grid-template-columns: 1fr; gap: 1rem; padding-top: 5rem; }.hero-copy { max-width: 720px; }.hero-visual { max-width: 620px; width: 100%; margin: 0 auto; }.service-grid { grid-template-columns: 1fr 1fr; }.service-card:last-child { grid-column: 1 / -1; min-height: 430px; }.about-grid { gap: 3rem; }.footer-grid { grid-template-columns: 1.4fr 1fr 1fr; }.footer-grid > div:last-child { grid-column: 1 / -1; }
}
@media (max-width: 991.98px) {
  .contact-inner { grid-template-columns: 1fr; min-height: auto; gap: 3rem; }.contact-copy { max-width: 680px; }.contact-form { width: 100%; max-width: 760px; }
}
@media (max-width: 767.98px) {
  .section { padding: 5rem 0; }.hero { min-height: auto; }.hero-grid { min-height: auto; padding-top: 4rem; }.hero h1 { font-size: clamp(2.8rem,13vw,4rem); }.hero-proof { flex-wrap: wrap; row-gap: 1.2rem; }.hero-proof div { min-width: 50%; }.hero-proof div:nth-child(3) { padding-left: 0; border-left: 0; }.hero-visual { min-height: 400px; }.card-code { left: 0; }.card-shield { right: 0; }.section-heading { grid-template-columns: 1fr; gap: 1.4rem; }.service-grid, .project-grid, .about-grid, .contact-inner { grid-template-columns: 1fr; }.service-card:last-child { grid-column: auto; }.service-card { min-height: 470px; }.about-panel { min-height: 400px; }.process-grid { grid-template-columns: 1fr 1fr; row-gap: 2.5rem; }.process-grid::before { display: none; }.contact-inner { min-height: auto; gap: 3rem; }.contact-copy { max-width: 660px; }.field-group input,.field-group select,.field-group textarea { font-size: 16px; }.footer-grid { grid-template-columns: 1fr 1fr; }.footer-grid > div:first-child,.footer-grid > div:last-child { grid-column: 1 / -1; }.footer-bottom { flex-direction: column; gap: .8rem; }
}
@media (max-width: 479.98px) {
  .site-container { padding-right: 1.15rem; padding-left: 1.15rem; }.social-link { width: 40px; height: 40px; }.social-link svg { width: 18px; height: 18px; }.social-extra { display: none; }.nav-actions { align-items: flex-start; flex-direction: column; }.hero-proof div { min-width: 100%; padding-left: 0; border-left: 0; }.hero-visual { min-height: 355px; }.main-card { right: 0; left: 0; }.floating-card { display: none; }.score-ring { width: 78px; height: 78px; padding-top: 20px; }.service-card { padding: 1.5rem; }.project-card-large .project-visual { height: 240px; }.project-visual { height: 230px; }.about-panel { min-height: 340px; }.binary-core { width: 110px; height: 110px; }.process-grid { grid-template-columns: 1fr; }.contact-form { padding: 1.35rem; border-radius: 14px; }.contact-form-grid { grid-template-columns: 1fr; }.field-group.field-full { grid-column: auto; }.form-submit-row { align-items: flex-start; flex-direction: column; }.footer-grid { grid-template-columns: 1fr; }.footer-grid > div { grid-column: 1 / -1; }
}
@media (max-width: 575.98px) {
  .content-page { min-height: auto; padding: 3.5rem 0; }.auth-card,.profile-form-card,.state-card { padding: 1.35rem; border-radius: 12px; }.form-actions { align-items: stretch; flex-direction: column; }.form-actions .button,.auth-card > form > .button,.profile-form-card > form > .button { width: 100%; }.text-action { text-align: center; }.dashboard-grid { grid-template-columns: 1fr; }.dashboard-card { min-height: 230px; padding: 1.4rem; }.profile-picture { width: 140px; height: 140px; }.content-page .row > [class*="col-"] { min-width: 0; }.alert { overflow-wrap: anywhere; }
}
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } *,*::before,*::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }.reveal { opacity: 1; transform: none; }.trust-slider { overflow-x: auto; }.trust-track { animation: none !important; }.trust-group[aria-hidden="true"] { display: none; } }
