:root {
  --af-bg: #050812;
  --af-bg-soft: #09111f;
  --af-panel: rgba(255, 255, 255, .055);
  --af-panel-strong: rgba(255, 255, 255, .085);
  --af-border: rgba(148, 163, 184, .18);
  --af-border-bright: rgba(56, 189, 248, .48);
  --af-text: #f8fafc;
  --af-muted: #a8b3c7;
  --af-soft: #dbeafe;
  --af-blue: #2579ff;
  --af-cyan: #22d3ee;
  --af-green: #22c55e;
  --af-radius: 8px;
  --af-shadow: 0 24px 80px rgba(0, 0, 0, .42);
  --af-font: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 92px;
}

body {
  margin: 0;
  color: var(--af-text);
  background:
    linear-gradient(180deg, rgba(37, 121, 255, .08), transparent 520px),
    var(--af-bg);
  font-family: var(--af-font);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -3;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(148, 163, 184, .035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(148, 163, 184, .035) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, .7), transparent 78%);
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
}

.container {
  width: min(100% - 32px, 1180px);
  max-width: 1180px;
}

.site-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  background: #030712;
  transition: opacity .35s ease, visibility .35s ease;
}

body.loaded .site-loader {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.loader-mark {
  display: grid;
  place-items: center;
  width: 74px;
  height: 74px;
  border-radius: var(--af-radius);
  color: #fff;
  font-weight: 900;
  background: linear-gradient(135deg, var(--af-blue), var(--af-cyan));
  box-shadow: 0 0 40px rgba(34, 211, 238, .36);
  animation: pulseMark 1.5s ease-in-out infinite;
}

.premium-nav {
  min-height: 76px;
  padding: 0;
  border-bottom: 1px solid rgba(148, 163, 184, .12);
  background: rgba(5, 8, 18, .78);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  transition: min-height .22s ease, background .22s ease, box-shadow .22s ease;
}

.premium-nav.nav-scrolled {
  min-height: 66px;
  background: rgba(5, 8, 18, .94);
  box-shadow: 0 18px 60px rgba(0, 0, 0, .34);
}

.nav-shell {
  width: min(100%, 1440px);
  padding-inline: clamp(16px, 3vw, 48px);
}

.brand-logo-img {
  width: clamp(150px, 14vw, 214px);
  height: auto;
  filter: drop-shadow(0 0 18px rgba(34, 211, 238, .32));
}

.nav-center {
  gap: clamp(.25rem, 1vw, 1rem);
}

.premium-nav .nav-link {
  position: relative;
  color: rgba(226, 232, 240, .72);
  font-size: .9rem;
  font-weight: 700;
  padding: 1.2rem .2rem;
}

.premium-nav .nav-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: .7rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--af-blue), var(--af-cyan));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .22s ease;
}

.premium-nav .nav-link:hover,
.premium-nav .nav-link.active {
  color: #fff;
}

.premium-nav .nav-link:hover::after,
.premium-nav .nav-link.active::after {
  transform: scaleX(1);
}

.nav-actions {
  display: flex;
  align-items: center;
  gap: .72rem;
}

.navbar-toggler {
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: rgba(255, 255, 255, .06);
}

.navbar-toggler:focus {
  box-shadow: 0 0 0 .2rem rgba(34, 211, 238, .18);
}

.navbar-toggler-icon {
  filter: invert(1);
}

.btn {
  min-height: 46px;
  border: 0;
  border-radius: var(--af-radius);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .65rem;
  padding: .75rem 1.05rem;
  font-weight: 800;
  letter-spacing: 0;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease;
}

.nav-cta,
.btn-primary-premium {
  color: #fff;
  background: linear-gradient(135deg, var(--af-blue), var(--af-cyan));
  box-shadow: 0 14px 34px rgba(37, 121, 255, .28);
}

.nav-cta {
  min-height: 42px;
  padding-inline: .95rem;
  font-size: .82rem;
}

.btn-primary-premium:hover,
.nav-cta:hover {
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 20px 54px rgba(34, 211, 238, .26);
}

.btn-outline-premium {
  color: #fff;
  border: 1px solid var(--af-border);
  background: rgba(255, 255, 255, .045);
}

.btn-outline-premium:hover {
  color: #fff;
  border-color: var(--af-border-bright);
  background: rgba(34, 211, 238, .08);
  transform: translateY(-2px);
}

.btn-ghost-premium {
  color: var(--af-cyan);
  border: 1px solid rgba(34, 211, 238, .22);
  background: rgba(34, 211, 238, .05);
}

.btn-ghost-premium:hover {
  color: #fff;
  border-color: rgba(34, 211, 238, .55);
  background: rgba(34, 211, 238, .1);
  transform: translateY(-2px);
}

.nav-whatsapp,
.whatsapp-float,
.back-to-top,
.assistant-toggle {
  display: grid;
  place-items: center;
  border-radius: var(--af-radius);
}

.nav-whatsapp {
  width: 42px;
  height: 42px;
  color: #fff;
  font-size: 1.25rem;
  border: 1px solid var(--af-border);
  background: rgba(255, 255, 255, .055);
}

.nav-whatsapp:hover {
  color: var(--af-green);
}

.hero-section {
  position: relative;
  min-height: min(760px, 100vh);
  display: grid;
  align-items: center;
  padding: clamp(112px, 13vh, 142px) 0 clamp(48px, 7vh, 76px);
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 76% 28%, rgba(34, 211, 238, .16), transparent 32rem),
    radial-gradient(circle at 16% 18%, rgba(37, 99, 235, .24), transparent 34rem),
    linear-gradient(180deg, #050816 0%, #070d1f 56%, var(--af-bg) 100%);
}

.hero-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(5, 8, 18, .88), rgba(5, 8, 18, .58) 54%, rgba(5, 8, 18, .78)),
    linear-gradient(180deg, rgba(5, 8, 18, .15), var(--af-bg));
}

#networkCanvas,
.hero-grid {
  position: absolute;
  inset: 0;
}

#networkCanvas {
  z-index: -1;
  width: 100%;
  height: 100%;
  opacity: .6;
}

.hero-grid {
  z-index: -2;
  background-image:
    linear-gradient(rgba(34, 211, 238, .055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(34, 211, 238, .045) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(circle at 50% 36%, rgba(0, 0, 0, .96), transparent 72%);
}

.hero-container {
  display: grid;
  grid-template-columns: minmax(0, 55%) minmax(360px, 45%);
  align-items: center;
  gap: clamp(2rem, 4.4vw, 4.5rem);
}

.hero-copy {
  max-width: 760px;
}

.hero-kicker,
.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .9rem;
  color: var(--af-cyan);
  font-size: clamp(.68rem, .75vw, .8rem);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .12em;
}

.hero-kicker::before,
.section-kicker::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--af-cyan);
  box-shadow: 0 0 20px rgba(34, 211, 238, .8);
}

.hero-copy h1 {
  max-width: 780px;
  margin: 0;
  font-size: clamp(3rem, 4.35vw, 4.5rem);
  line-height: .99;
  font-weight: 900;
  letter-spacing: -.045em;
  text-wrap: balance;
  overflow-wrap: normal;
}

.hero-lead {
  max-width: 700px;
  margin: 1.1rem 0 0;
  color: rgba(226, 232, 240, .82);
  font-size: clamp(1rem, 1.14vw, 1.15rem);
  line-height: 1.68;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .95rem;
  margin-top: 1.55rem;
}

.hero-actions .btn {
  min-height: 54px;
  padding-inline: 1.35rem;
}

.hero-proof {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  margin-top: 1.4rem;
}

.hero-proof span {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  min-height: 42px;
  padding: .58rem .82rem;
  color: var(--af-muted);
  font-size: .84rem;
  font-weight: 800;
  border: 1px solid rgba(34, 211, 238, .13);
  border-radius: 999px;
  background: rgba(255, 255, 255, .045);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .045);
}

.hero-proof strong {
  color: #fff;
}

.hero-dashboard {
  position: relative;
  border: 1px solid rgba(34, 211, 238, .22);
  border-radius: 18px;
  overflow: hidden;
  background:
    radial-gradient(circle at 22% 0%, rgba(34, 211, 238, .18), transparent 34%),
    linear-gradient(180deg, rgba(15, 23, 42, .88), rgba(3, 7, 18, .72));
  box-shadow: 0 28px 88px rgba(0, 0, 0, .35), 0 0 62px rgba(37, 99, 235, .14), inset 0 1px 0 rgba(255, 255, 255, .08);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.hero-dashboard::before {
  content: "";
  position: absolute;
  inset: 10px;
  pointer-events: none;
  border: 1px solid rgba(255, 255, 255, .06);
  border-radius: 14px;
}

.dashboard-top {
  display: flex;
  align-items: center;
  gap: .45rem;
  min-height: 50px;
  padding: 0 1rem;
  border-bottom: 1px solid var(--af-border);
  background: rgba(255, 255, 255, .035);
}

.dashboard-top span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(148, 163, 184, .5);
}

.dashboard-top strong {
  margin-left: auto;
  color: #dff7ff;
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.dashboard-status {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .62rem;
  padding: .85rem 1rem 0;
  color: var(--af-muted);
  font-size: .78rem;
  font-weight: 850;
}

.dashboard-status span {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: .4rem;
  padding: .48rem .58rem;
  border: 1px solid rgba(34, 211, 238, .14);
  border-radius: 999px;
  background: rgba(255, 255, 255, .045);
}

.dashboard-status i {
  color: #22c55e;
}

.dashboard-body {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .76rem;
  padding: 1rem;
}

.dashboard-card {
  position: relative;
  overflow: hidden;
  min-height: 112px;
  padding: .95rem;
  border: 1px solid var(--af-border);
  border-radius: 18px;
  background: rgba(255, 255, 255, .052);
  transition: transform .24s ease, border-color .24s ease, background .24s ease;
}

.dashboard-card:hover {
  transform: translateY(-3px);
  border-color: rgba(34, 211, 238, .34);
  background: rgba(34, 211, 238, .065);
}

.dashboard-card.primary {
  background: linear-gradient(135deg, rgba(37, 121, 255, .24), rgba(34, 211, 238, .08));
  border-color: var(--af-border-bright);
}

.dashboard-card i {
  color: var(--af-cyan);
  font-size: 1.25rem;
}

.dashboard-card span,
.dashboard-card strong {
  display: block;
}

.dashboard-card span {
  margin-top: .78rem;
  color: #fff;
  font-weight: 900;
}

.dashboard-card strong {
  margin-top: .28rem;
  color: var(--af-muted);
  font-size: .9rem;
}

.section {
  padding: clamp(76px, 9vw, 122px) 0;
  position: relative;
}

.section-heading {
  max-width: 760px;
  margin-bottom: clamp(2rem, 5vw, 3.4rem);
}

.section-heading.narrow {
  max-width: 690px;
  margin-inline: auto;
  text-align: center;
}

.section-heading h2,
.contact-copy h2,
.ceo-copy h2 {
  margin: 0;
  font-size: clamp(2rem, 4.2vw, 4rem);
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: 0;
}

.section-heading p,
.contact-copy p,
.ceo-copy p {
  margin: 1rem 0 0;
  color: var(--af-muted);
  line-height: 1.75;
  font-size: 1.02rem;
}

.stats-section {
  position: relative;
  z-index: 2;
  margin-top: -44px;
}

.stats-grid,
.services-grid,
.process-grid,
.portfolio-grid,
.why-grid,
.testimonials-grid {
  display: grid;
  gap: 1rem;
}

.stats-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.stats-grid article,
.premium-card,
.process-step,
.testimonial-card,
.contact-form {
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: var(--af-panel);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .055);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.stats-grid article {
  min-height: 148px;
  padding: 1.25rem;
  display: grid;
  align-content: center;
  gap: .35rem;
}

.stats-grid i,
.premium-card i {
  color: var(--af-cyan);
  font-size: 1.45rem;
}

.stats-grid strong {
  color: #fff;
  font-size: clamp(2rem, 3.5vw, 3.1rem);
  line-height: 1;
  font-weight: 900;
}

.stats-grid span {
  color: var(--af-muted);
  font-weight: 700;
}

.services-grid,
.why-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.premium-card {
  min-height: 246px;
  padding: 1.5rem;
  transition: transform .24s ease, border-color .24s ease, background .24s ease, box-shadow .24s ease;
}

.service-card {
  overflow: hidden;
}

.service-image {
  position: relative;
  height: 156px;
  margin: -1.5rem -1.5rem 1.25rem;
  overflow: hidden;
  border-bottom: 1px solid var(--af-border);
  background:
    radial-gradient(circle at 30% 20%, rgba(34, 211, 238, .18), transparent 38%),
    rgba(15, 23, 42, .82);
}

.service-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 42%, rgba(5, 8, 18, .78));
}

.service-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease, filter .35s ease;
}

.service-card:hover .service-image img {
  filter: saturate(1.08) contrast(1.04);
  transform: scale(1.05);
}

.premium-card:hover,
.project-card:hover,
.process-step:hover,
.testimonial-card:hover {
  transform: translateY(-6px);
  border-color: var(--af-border-bright);
  background: var(--af-panel-strong);
  box-shadow: 0 24px 64px rgba(0, 0, 0, .28), 0 0 0 1px rgba(34, 211, 238, .08);
}

.premium-card h3,
.process-step h3,
.project-card h3,
.testimonial-card strong {
  margin: 1.2rem 0 .75rem;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 900;
}

.premium-card p,
.process-step p,
.project-card p,
.testimonial-card p {
  margin: 0;
  color: var(--af-muted);
  line-height: 1.68;
}

.process-section,
.testimonials-section,
.footer-premium {
  background: linear-gradient(180deg, rgba(15, 23, 42, .22), rgba(15, 23, 42, .08));
}

.process-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  position: relative;
}

.process-step {
  min-height: 232px;
  padding: 1.35rem;
  transition: transform .24s ease, border-color .24s ease, background .24s ease;
}

.process-step span {
  display: grid;
  place-items: center;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  color: #fff;
  font-weight: 900;
  background: linear-gradient(135deg, var(--af-blue), var(--af-cyan));
  box-shadow: 0 0 28px rgba(34, 211, 238, .22);
}

.process-step.active {
  border-color: var(--af-border-bright);
}

.portfolio-section {
  overflow: hidden;
}

.portfolio-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.2rem;
}

.project-card {
  overflow: hidden;
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: rgba(255, 255, 255, .045);
  transition: transform .24s ease, border-color .24s ease, background .24s ease, box-shadow .24s ease;
}

.project-image {
  position: relative;
  min-height: 260px;
  aspect-ratio: 16 / 10;
  background:
    linear-gradient(135deg, rgba(37, 121, 255, .18), rgba(34, 211, 238, .08)),
    #0b1220;
  overflow: hidden;
}

.project-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease, filter .35s ease;
}

.project-card:hover .project-image img {
  transform: scale(1.04);
  filter: saturate(1.08) contrast(1.04);
}

.project-image span {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  max-width: calc(100% - 2rem);
  padding: .45rem .7rem;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 999px;
  color: #fff;
  font-size: .75rem;
  font-weight: 900;
  background: rgba(5, 8, 18, .72);
  backdrop-filter: blur(12px);
}

.project-content {
  padding: 1.45rem;
}

.project-content h3 {
  margin-top: 0;
}

.project-tech,
.badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.project-tech {
  margin: 1.25rem 0;
}

.project-tech span,
.badge-row span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: .34rem .68rem;
  border: 1px solid var(--af-border);
  border-radius: 999px;
  color: var(--af-soft);
  font-size: .78rem;
  font-weight: 800;
  background: rgba(255, 255, 255, .045);
}

.project-result {
  padding: 1rem;
  border: 1px solid rgba(34, 211, 238, .18);
  border-radius: var(--af-radius);
  background: rgba(34, 211, 238, .055);
}

.project-result strong {
  display: block;
  margin-bottom: .35rem;
  color: var(--af-cyan);
  font-size: .82rem;
  text-transform: uppercase;
}

.project-link {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin-top: 1.1rem;
  color: #fff;
  font-weight: 900;
}

.project-link:hover {
  color: var(--af-cyan);
}

.ceo-layout {
  display: grid;
  grid-template-columns: minmax(280px, 40%) minmax(0, 60%);
  gap: clamp(1.5rem, 5vw, 4.2rem);
  align-items: center;
}

.ceo-photo {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--af-border-bright);
  border-radius: var(--af-radius);
  background: #0b1220;
  box-shadow: var(--af-shadow), 0 0 70px rgba(37, 99, 235, .24);
  aspect-ratio: 4 / 5;
}

.ceo-photo::before {
  content: "";
  position: absolute;
  inset: 12px;
  z-index: 1;
  pointer-events: none;
  border: 1px solid rgba(34, 211, 238, .28);
  border-radius: calc(var(--af-radius) - 10px);
  box-shadow: inset 0 0 34px rgba(34, 211, 238, .08);
}

.ceo-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform .35s ease, filter .35s ease;
}

.ceo-photo:hover img {
  filter: saturate(1.08) contrast(1.04);
  transform: scale(1.025);
}

.ceo-copy .role {
  margin-top: .5rem;
  color: var(--af-cyan);
  font-weight: 900;
}

.ceo-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .9rem;
  margin: 1.4rem 0;
}

.ceo-metrics div {
  padding: 1rem;
  border: 1px solid var(--af-border);
  border-radius: 20px;
  background: linear-gradient(145deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .025));
  box-shadow: 0 18px 40px rgba(0, 0, 0, .18);
  transition: transform .24s ease, border-color .24s ease, background .24s ease;
}

.ceo-metrics div:hover {
  transform: translateY(-4px);
  border-color: var(--af-border-bright);
  background: rgba(34, 211, 238, .07);
}

.ceo-metrics i {
  color: var(--af-cyan);
  margin-bottom: .55rem;
}

.ceo-metrics strong,
.ceo-metrics span {
  display: block;
}

.ceo-metrics strong {
  color: var(--af-white);
  font-size: clamp(1.45rem, 3vw, 2.1rem);
  line-height: 1;
}

.ceo-metrics span {
  margin-top: .35rem;
  color: var(--af-muted);
  font-size: .82rem;
  font-weight: 800;
}

.ceo-specialties span::before {
  content: "✓";
  color: var(--af-cyan);
  margin-right: .4rem;
}

.ceo-copy blockquote {
  margin: 1.5rem 0 0;
  padding: 1.2rem;
  border-left: 3px solid var(--af-cyan);
  border-radius: var(--af-radius);
  color: #fff;
  font-size: 1.12rem;
  line-height: 1.6;
  background: rgba(255, 255, 255, .045);
}

.ceo-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  margin-top: 1.4rem;
}

.why-grid {
  margin-top: 2.4rem;
}

.testimonials-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.testimonial-card {
  min-height: 240px;
  padding: 1.45rem;
  transition: transform .24s ease, border-color .24s ease, background .24s ease;
}

.stars {
  color: #facc15;
  letter-spacing: 0;
  font-size: 1rem;
}

.testimonial-card strong,
.testimonial-card span {
  display: block;
}

.testimonial-card strong {
  margin-top: 1.2rem;
  margin-bottom: .2rem;
}

.testimonial-card span {
  color: var(--af-cyan);
  font-size: .88rem;
  font-weight: 800;
}

.premium-accordion {
  max-width: 900px;
  margin: 0 auto;
  display: grid;
  gap: .8rem;
}

.premium-accordion .accordion-item {
  overflow: hidden;
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: rgba(255, 255, 255, .045);
}

.premium-accordion .accordion-button {
  color: #fff;
  font-weight: 900;
  background: transparent;
  box-shadow: none;
}

.premium-accordion .accordion-button:not(.collapsed) {
  color: var(--af-cyan);
  background: rgba(34, 211, 238, .055);
}

.premium-accordion .accordion-button::after {
  filter: invert(1);
}

.premium-accordion .accordion-body {
  color: var(--af-muted);
  line-height: 1.7;
}

.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(360px, .78fr);
  gap: clamp(1.4rem, 5vw, 4rem);
  align-items: start;
}

.contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  margin-top: 1.6rem;
}

.contact-data {
  display: grid;
  gap: .8rem;
  margin-top: 1.7rem;
}

.contact-data span,
.footer-grid span {
  display: flex;
  align-items: center;
  gap: .65rem;
  color: var(--af-muted);
}

.contact-data i,
.footer-grid i {
  color: var(--af-cyan);
}

.contact-form {
  padding: 1.4rem;
}

.contact-form h3 {
  margin: 0 0 1rem;
  color: #fff;
  font-weight: 900;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
}

.form-grid .full {
  grid-column: 1 / -1;
}

.contact-form label {
  display: grid;
  gap: .4rem;
  color: var(--af-soft);
  font-size: .86rem;
  font-weight: 800;
}

.contact-form .form-control {
  min-height: 50px;
  color: #fff;
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: rgba(3, 7, 18, .74);
}

.contact-form textarea.form-control {
  min-height: 138px;
  resize: vertical;
}

.contact-form .form-control:focus {
  color: #fff;
  border-color: var(--af-border-bright);
  background: rgba(3, 7, 18, .92);
  box-shadow: 0 0 0 .16rem rgba(34, 211, 238, .14);
}

.footer-premium {
  padding: 72px 0 32px;
  border-top: 1px solid var(--af-border);
}

.footer-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1.4fr) repeat(3, minmax(160px, .7fr));
  gap: 2rem;
}

.footer-logo {
  width: 210px;
  margin-bottom: 1rem;
}

.footer-grid h3 {
  margin: 0 0 1rem;
  color: #fff;
  font-size: .96rem;
  font-weight: 900;
  text-transform: uppercase;
}

.footer-grid a {
  display: block;
  margin-bottom: .72rem;
  color: var(--af-muted);
}

.footer-grid a:hover {
  color: var(--af-cyan);
}

.footer-company p {
  max-width: 430px;
  color: var(--af-muted);
  line-height: 1.7;
}

.social-links-footer {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-top: 1rem;
}

.social-links-footer a {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  margin: 0;
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: rgba(255, 255, 255, .045);
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 2.2rem;
  padding-top: 1.4rem;
  border-top: 1px solid var(--af-border);
  color: var(--af-muted);
}

.footer-bottom p {
  margin: 0;
}

.virtual-assistant {
  position: fixed;
  right: 18px;
  bottom: 158px;
  z-index: 90;
}

.assistant-toggle {
  position: relative;
  width: 58px;
  height: 58px;
  color: #fff;
  border: 1px solid var(--af-border-bright);
  background: linear-gradient(135deg, var(--af-blue), var(--af-cyan));
  box-shadow: 0 16px 44px rgba(37, 121, 255, .28);
}

.assistant-toggle span {
  position: absolute;
  right: -3px;
  bottom: -5px;
  padding: .12rem .32rem;
  border-radius: 999px;
  font-size: .62rem;
  font-weight: 900;
  background: #020617;
}

.assistant-panel {
  position: absolute;
  right: 0;
  bottom: 72px;
  width: 260px;
  padding: 1rem;
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: rgba(5, 8, 18, .94);
  box-shadow: var(--af-shadow);
  transition: opacity .22s ease, transform .22s ease;
}

.virtual-assistant.open .assistant-panel {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.assistant-panel strong {
  color: #fff;
}

.assistant-panel p {
  margin: .55rem 0 .8rem;
  color: var(--af-muted);
}

.assistant-panel a {
  color: var(--af-cyan);
  font-weight: 900;
}

.whatsapp-float,
.back-to-top {
  position: fixed;
  right: 18px;
  z-index: 89;
  border: 1px solid var(--af-border);
  color: #fff;
}

.whatsapp-float {
  bottom: 22px;
  width: 58px;
  height: 58px;
  font-size: 1.7rem;
  background: #16a34a;
  box-shadow: 0 18px 42px rgba(22, 163, 74, .32);
}

.back-to-top {
  bottom: 92px;
  width: 44px;
  height: 44px;
  opacity: 0;
  visibility: hidden;
  background: rgba(255, 255, 255, .07);
  transition: opacity .22s ease, visibility .22s ease, transform .22s ease;
}

.back-to-top.show {
  opacity: 1;
  visibility: visible;
}

.image-fallback::before {
  content: "AFCyber Solutions";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: var(--af-cyan);
  font-weight: 900;
  background:
    linear-gradient(135deg, rgba(37, 121, 255, .2), rgba(34, 211, 238, .09)),
    #0b1220;
}

.project-icon-fallback {
  display: grid;
  place-items: center;
  align-content: center;
  gap: .85rem;
  isolation: isolate;
}

.project-icon-fallback::before {
  content: "";
}

.project-icon-fallback i {
  position: relative;
  z-index: 1;
  color: var(--af-cyan);
  font-size: clamp(2.8rem, 6vw, 4.8rem);
  text-shadow: 0 0 32px rgba(34, 211, 238, .45);
}

.project-icon-fallback span {
  position: relative;
  left: auto;
  bottom: auto;
  z-index: 1;
}

.mini-whatsapp {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  margin-top: 1.15rem;
  color: var(--af-cyan);
  font-size: .88rem;
  font-weight: 900;
}

.mini-whatsapp::after {
  content: "\f061";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: .76rem;
}

.service-gallery-section,
.success-section,
.trust-security-section {
  background: linear-gradient(180deg, rgba(15, 23, 42, .16), rgba(15, 23, 42, .04));
}

.filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-bottom: 1.4rem;
}

.filter-btn {
  min-height: 42px;
  padding: .58rem .9rem;
  color: var(--af-soft);
  font-weight: 850;
  border: 1px solid var(--af-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, .045);
  transition: transform .22s ease, border-color .22s ease, background .22s ease;
}

.filter-btn:hover,
.filter-btn.active {
  color: #fff;
  border-color: var(--af-border-bright);
  background: rgba(34, 211, 238, .12);
  transform: translateY(-2px);
}

.gallery-grid,
.success-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.gallery-item,
.success-card {
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: var(--af-panel);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .055);
  transition: opacity .22s ease, transform .24s ease, border-color .24s ease, background .24s ease;
}

.gallery-item {
  min-height: 190px;
  padding: 1.25rem;
}

.gallery-item.is-hidden {
  display: none;
}

.gallery-item i {
  color: var(--af-cyan);
  font-size: 1.55rem;
}

.gallery-item h3,
.success-card h3 {
  margin: 1rem 0 .55rem;
  color: #fff;
  font-size: 1.12rem;
  font-weight: 900;
}

.gallery-item p,
.success-card p {
  margin: 0;
  color: var(--af-muted);
  line-height: 1.65;
}

.gallery-item:hover,
.success-card:hover {
  transform: translateY(-6px);
  border-color: var(--af-border-bright);
  background: var(--af-panel-strong);
}

.success-card {
  min-height: 270px;
  padding: 1.35rem;
}

.success-card span {
  display: inline-flex;
  padding: .34rem .62rem;
  color: var(--af-cyan);
  font-size: .75rem;
  font-weight: 900;
  border: 1px solid rgba(34, 211, 238, .2);
  border-radius: 999px;
  background: rgba(34, 211, 238, .06);
}

.success-card p + p {
  margin-top: .65rem;
}

.form-intro {
  margin: -.35rem 0 1rem;
  color: var(--af-muted);
}

.form-status {
  display: none;
  margin-bottom: 1rem;
  padding: .75rem .9rem;
  border-radius: var(--af-radius);
  font-size: .9rem;
  font-weight: 800;
}

.form-status.show {
  display: block;
}

.form-status.success {
  color: #bbf7d0;
  border: 1px solid rgba(34, 197, 94, .32);
  background: rgba(34, 197, 94, .1);
}

.form-status.error {
  color: #fecdd3;
  border: 1px solid rgba(244, 63, 94, .32);
  background: rgba(244, 63, 94, .1);
}

.premium-quote-form {
  position: relative;
  overflow: hidden;
}

.premium-quote-form::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: linear-gradient(90deg, var(--af-blue), var(--af-cyan));
}

.contact-form .form-control.is-valid {
  border-color: rgba(34, 197, 94, .78);
  box-shadow: 0 0 0 .12rem rgba(34, 197, 94, .12);
}

.contact-form .form-control.is-invalid,
.contact-form.was-validated .form-control:invalid {
  border-color: rgba(244, 63, 94, .82);
  box-shadow: 0 0 0 .12rem rgba(244, 63, 94, .13);
}

.map-shell {
  overflow: hidden;
  min-height: 280px;
  margin-top: 1.4rem;
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: rgba(255, 255, 255, .045);
  box-shadow: var(--af-shadow);
}

.map-shell iframe {
  width: 100%;
  height: 320px;
  display: block;
  border: 0;
  filter: saturate(.88) contrast(1.05);
}

.skeleton-media {
  position: relative;
}

.skeleton-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 0 35%, rgba(255, 255, 255, .09) 45%, transparent 56% 100%);
  animation: skeletonSweep 1.45s linear infinite;
}

.help-bot {
  position: fixed;
  right: 22px;
  bottom: 92px;
  z-index: 92;
}

.help-bot-toggle {
  display: flex;
  align-items: center;
  gap: .45rem;
  min-height: 56px;
  padding: .75rem .9rem;
  color: #fff;
  font-weight: 900;
  border: 1px solid var(--af-border-bright);
  border-radius: var(--af-radius);
  background: linear-gradient(135deg, rgba(37, 121, 255, .95), rgba(34, 211, 238, .92));
  box-shadow: 0 18px 52px rgba(37, 121, 255, .32);
  animation: helpBotPulse 2.8s ease-in-out infinite;
}

.help-bot-panel {
  position: absolute;
  right: 0;
  bottom: 68px;
  width: min(340px, calc(100vw - 32px));
  max-height: min(560px, calc(100vh - 128px));
  overflow: auto;
  padding: 1rem;
  opacity: 0;
  transform: translateY(10px) scale(.98);
  pointer-events: none;
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: rgba(5, 8, 18, .94);
  box-shadow: var(--af-shadow);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  transition: opacity .22s ease, transform .22s ease;
}

.help-bot.open .help-bot-panel {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.help-bot-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: .7rem;
}

.help-bot-header strong {
  color: #fff;
  font-size: 1rem;
}

.help-bot-close {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  color: #fff;
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: rgba(255, 255, 255, .06);
}

.help-bot-panel p {
  color: var(--af-muted);
  line-height: 1.6;
}

.help-bot-options {
  display: grid;
  gap: .48rem;
}

.help-bot-options a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .7rem;
  min-height: 40px;
  padding: .58rem .7rem;
  color: var(--af-soft);
  font-size: .88rem;
  font-weight: 850;
  border: 1px solid var(--af-border);
  border-radius: var(--af-radius);
  background: rgba(255, 255, 255, .045);
}

.help-bot-options a::after {
  content: "\f232";
  color: #22c55e;
  font-family: "Font Awesome 6 Brands";
}

.help-bot-options a.primary {
  color: #fff;
  border-color: rgba(34, 197, 94, .38);
  background: rgba(34, 197, 94, .12);
}

@keyframes skeletonSweep {
  from { transform: translateX(-100%); }
  to { transform: translateX(100%); }
}

@keyframes helpBotPulse {
  0%, 100% { box-shadow: 0 18px 52px rgba(37, 121, 255, .32), 0 0 0 0 rgba(34, 211, 238, .28); }
  50% { box-shadow: 0 18px 52px rgba(37, 121, 255, .32), 0 0 0 10px rgba(34, 211, 238, 0); }
}

@keyframes pulseMark {
  50% {
    transform: scale(1.04);
    box-shadow: 0 0 54px rgba(34, 211, 238, .48);
  }
}

.legal-page {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(37, 99, 235, .22), transparent 34rem),
    radial-gradient(circle at bottom right, rgba(34, 211, 238, .14), transparent 30rem),
    var(--af-bg);
}

.legal-hero {
  padding-top: 148px;
  padding-bottom: 48px;
}

.legal-hero h1 {
  max-width: 820px;
  margin: 1rem 0;
  font-size: clamp(2.6rem, 6vw, 5rem);
  letter-spacing: -.06em;
}

.legal-hero p {
  max-width: 760px;
  color: var(--af-muted);
  font-size: 1.12rem;
  line-height: 1.8;
}

.legal-content-section {
  padding-top: 24px;
}

.legal-card {
  padding: clamp(1.5rem, 4vw, 3rem);
  border: 1px solid var(--af-border);
  border-radius: 32px;
  background: linear-gradient(145deg, rgba(15, 23, 42, .88), rgba(2, 6, 23, .74));
  box-shadow: var(--af-shadow);
}

.legal-card h2 {
  margin-top: 1.7rem;
  color: var(--af-white);
  font-size: 1.35rem;
}

.legal-card h2:first-child {
  margin-top: 0;
}

.legal-card p {
  color: var(--af-muted);
  line-height: 1.8;
}

.legal-card a {
  color: var(--af-cyan);
  text-decoration: none;
}

.legal-card a:hover {
  color: var(--af-white);
}

@media (max-width: 1199px) {
  .premium-nav .navbar-collapse {
    margin-top: .85rem;
    padding: 1rem;
    border: 1px solid var(--af-border);
    border-radius: var(--af-radius);
    background: rgba(5, 8, 18, .98);
  }

  .premium-nav .nav-link {
    padding: .75rem .25rem;
  }

  .nav-actions {
    margin-top: .8rem;
    justify-content: flex-start;
  }

  .hero-container,
  .contact-layout {
    grid-template-columns: 1fr;
  }

  .hero-section {
    min-height: auto;
    padding-top: 124px;
  }

  .hero-copy {
    max-width: 860px;
  }

  .hero-copy h1 {
    max-width: 780px;
    font-size: clamp(2.75rem, 5.1vw, 3.625rem);
  }

  .hero-dashboard {
    max-width: 680px;
  }

  .services-grid,
  .why-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .process-grid,
  .gallery-grid,
  .success-grid,
  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  .hero-copy h1 {
    font-size: clamp(2.45rem, 6.2vw, 3.2rem);
  }

  .stats-grid,
  .portfolio-grid,
  .testimonials-grid,
  .ceo-layout {
    grid-template-columns: 1fr;
  }

  .ceo-photo {
    max-width: 440px;
  }

  .ceo-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .container {
    width: min(100% - 24px, 1180px);
  }

  .brand-logo-img {
    width: 158px;
  }

  .nav-actions {
    display: grid;
    grid-template-columns: 1fr 44px;
  }

  .nav-cta {
    width: 100%;
  }

  .hero-section {
    min-height: auto;
    padding: 108px 0 58px;
  }

  .hero-copy h1 {
    font-size: clamp(2.35rem, 11vw, 2.625rem);
    line-height: 1.03;
  }

  .hero-lead {
    font-size: 1rem;
  }

  .hero-actions .btn,
  .contact-actions .btn,
  .ceo-actions .btn {
    width: 100%;
  }

  .services-grid,
  .why-grid,
  .process-grid,
  .gallery-grid,
  .success-grid,
  .form-grid,
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .project-image {
    min-height: 220px;
  }

  .ceo-metrics {
    grid-template-columns: 1fr;
  }

  .hero-proof,
  .dashboard-status,
  .dashboard-body {
    grid-template-columns: 1fr;
  }

  .hero-proof {
    display: grid;
  }

  .dashboard-card {
    min-height: auto;
    padding: .9rem;
  }

  .dashboard-card span {
    margin-top: .55rem;
  }

  .virtual-assistant,
  .help-bot {
    right: 14px;
    bottom: 76px;
  }

  .help-bot-toggle span {
    display: none;
  }

  .help-bot-toggle {
    width: 58px;
    justify-content: center;
    padding: 0;
  }

  .whatsapp-float {
    right: 14px;
    bottom: 18px;
  }

  .back-to-top {
    right: 21px;
    bottom: 88px;
  }
}

@media (max-width: 480px) {
  .hero-kicker,
  .section-kicker {
    font-size: .7rem;
  }

  .dashboard-card {
    min-height: 104px;
  }

  .footer-bottom {
    font-size: .9rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }
}
