﻿:root {
      color-scheme: dark;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      font-family: "Segoe UI Variable", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
      background:
        radial-gradient(circle at top left, rgba(139, 92, 246, 0.18), transparent 35%),
        radial-gradient(circle at top right, rgba(56, 189, 248, 0.12), transparent 28%),
        linear-gradient(180deg, #04070f 0%, #070b14 40%, #04070f 100%);
      color: #e8eef9;
      font-size: 17px;
    }

    body::selection {
      background: #8b5cf6;
      color: #ffffff;
    }

    .font-display {
      font-family: "Bahnschrift SemiCondensed", "Trebuchet MS", "Avenir Next Condensed", "Segoe UI", Arial, sans-serif;
    }

    .font-sans {
      font-family: "Segoe UI Variable", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
    }

    .no-scrollbar::-webkit-scrollbar {
      display: none;
    }

    .no-scrollbar {
      -ms-overflow-style: none;
      scrollbar-width: none;
    }

    .surface {
      background: rgba(15, 23, 42, 0.78);
      backdrop-filter: blur(18px);
      border: 1px solid rgba(148, 163, 184, 0.16);
      box-shadow: 0 18px 60px rgba(2, 6, 23, 0.55);
    }

    .home-landing-page main {
      max-width: 88rem;
    }

    .surface-hero {
      background:
        linear-gradient(135deg, rgba(15, 23, 42, 0.9), rgba(19, 27, 49, 0.86)),
        rgba(15, 23, 42, 0.68);
      backdrop-filter: blur(18px);
      border: 1px solid rgba(148, 163, 184, 0.12);
      box-shadow: 0 24px 80px rgba(139, 92, 246, 0.24);
    }

    .section-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      border-radius: 9999px;
      border: 1px solid rgba(255, 255, 255, 0.08);
      padding: 0.25rem 0.75rem;
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 0.24em;
      text-transform: uppercase;
    }

    .site-header-shell {
      padding: 1rem 1.2rem;
      max-width: 70rem;
      margin-inline: auto;
    }

    .site-header-copy p:first-child {
      color: #aab8ca;
    }

    .site-header-copy p:last-child {
      color: #f8fafc;
      font-size: 0.98rem;
      line-height: 1.45;
    }

    .btn-primary,
    .btn-secondary {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      border-radius: 1rem;
      padding: 1rem 1.5rem;
      font-size: 0.98rem;
      transition: transform 200ms ease, background-color 200ms ease, color 200ms ease, border-color 200ms ease;
    }

    .btn-primary {
      background: linear-gradient(90deg, #8b5cf6, #38bdf8);
      color: #fff;
      font-weight: 700;
      box-shadow: 0 24px 80px rgba(139, 92, 246, 0.24);
    }

    .btn-secondary {
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: rgba(255, 255, 255, 0.05);
      color: #f8fafc;
      font-weight: 600;
    }

    .btn-primary:hover,
    .btn-secondary:hover {
      transform: translateY(-2px);
    }

    .nav-link {
      border-radius: 9999px;
      padding: 0.5rem 1rem;
      font-size: 0.92rem;
      font-weight: 600;
      color: #e2e8f0;
      transition: background-color 200ms ease, color 200ms ease;
    }

    .nav-link:hover {
      background: rgba(255, 255, 255, 0.05);
      color: #fff;
    }

    .nav-cta {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      border-radius: 9999px;
      background: linear-gradient(90deg, #8b5cf6, #38bdf8);
      padding: 0.5rem 1rem;
      font-size: 0.92rem;
      font-weight: 600;
      color: #fff;
      box-shadow: 0 24px 80px rgba(139, 92, 246, 0.24);
      transition: transform 200ms ease;
    }

    .nav-cta:hover {
      transform: translateY(-2px);
    }

    .metric-card {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      border-radius: 1rem;
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: rgba(255, 255, 255, 0.06);
      padding: 1rem;
      text-align: center;
      min-height: 7.4rem;
      gap: 0.45rem;
    }

    .hero-metrics .metric-card p {
      margin: 0;
      width: 100%;
      text-align: center;
    }

    .hero-impact-card {
      justify-content: center;
    }

    .hero-impact-text {
      display: block;
      text-align: center;
    }

    .product-card {
      border-radius: 1rem;
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: rgba(255, 255, 255, 0.05);
      padding: 1rem;
      text-align: center;
    }

    .feature-item {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      border-radius: 1rem;
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: rgba(255, 255, 255, 0.06);
      padding: 0.75rem 1rem;
    }

    .play-badge {
      display: flex;
      height: 3.5rem;
      width: 3.5rem;
      align-items: center;
      justify-content: center;
      border-radius: 9999px;
      background: rgba(139, 92, 246, 0.9);
      color: #fff;
      box-shadow: 0 24px 80px rgba(139, 92, 246, 0.24);
    }

    .spotlight-panel {
      border-radius: 2rem;
      border: 1px solid rgba(139, 92, 246, 0.2);
      background: linear-gradient(180deg, #8b5cf6 0%, #4f46e5 100%);
      padding: 1.5rem;
      text-align: center;
      box-shadow: 0 24px 80px rgba(139, 92, 246, 0.24);
    }

    .pill-link {
      border-radius: 1rem;
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: rgba(255, 255, 255, 0.05);
      padding: 0.75rem 1rem;
      font-size: 0.92rem;
      font-weight: 500;
      color: #e2e8f0;
      transition: background-color 200ms ease, color 200ms ease;
    }

    .site-header-copy p:last-child {
      color: #f8fafc;
    }

    .hero-content > p,
    .surface p,
    .feature-item p,
    .product-card span,
    .pill-link {
      letter-spacing: 0.01em;
    }

    .hero-title {
      letter-spacing: 0.015em;
      text-wrap: balance;
    }

    .hero-mobile-photo {
      opacity: 0.42 !important;
      filter: grayscale(0.25) brightness(0.88) contrast(1.08);
    }

    .hero-mobile-overlay {
      background: linear-gradient(180deg, rgba(6, 10, 18, 0.3) 0%, rgba(6, 10, 18, 0.56) 58%, rgba(6, 10, 18, 0.82) 100%) !important;
    }

    .hero-mobile-glow {
      opacity: 0.75;
    }

    .hero-desktop-photo {
      opacity: 0.62 !important;
      filter: grayscale(0.18) brightness(0.92) contrast(1.08);
      object-position: center top;
    }

    .hero-desktop-overlay {
      background: linear-gradient(135deg, rgba(99, 68, 201, 0.12), rgba(8, 12, 22, 0.24) 48%, rgba(14, 165, 233, 0.08)) !important;
    }

    .hero-content > p {
      color: #dbe7f5;
      font-size: 1.1rem;
      line-height: 1.85;
    }

    .surface .text-slate-300 {
      color: #d8e3f0;
    }

    .surface .text-slate-400 {
      color: #b9c7d8;
    }

    .surface .text-sm {
      font-size: 1rem;
      line-height: 1.72;
    }

    section h2:not(.hero-title) {
      letter-spacing: 0.01em;
      text-wrap: balance;
    }

    .section-lead-single {
      margin-inline: auto;
      text-align: center;
    }

    .section-lead {
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
    }

    .section-lead > p {
      margin-left: auto;
      margin-right: auto;
      text-align: center;
    }

    section h3 {
      letter-spacing: 0.01em;
    }

    #problema p,
    #metodo p,
    #autoridade p,
    #depoimentos p,
    #cursos p,
    #equipamentos p,
    #contato p {
      text-wrap: pretty;
    }

    #problema .surface,
    #metodo .surface,
    #autoridade .surface,
    #depoimentos .surface,
    #cursos .surface,
    #equipamentos .surface,
    #contato .surface {
      backdrop-filter: blur(20px);
    }

    @media (min-width: 1024px) {
      .site-header {
        padding-left: 2rem;
        padding-right: 2rem;
      }

      .hero-content {
        padding: 3rem 3rem 3.2rem;
      }

      .hero-title {
        font-size: 4.35rem;
        line-height: 0.92;
      }

      .hero-content > p {
        max-width: 40ch;
      }

      #problema h2,
      #metodo h2,
      #autoridade h2,
      #depoimentos h2,
      #equipamentos h2 {
        font-size: 3.35rem;
        line-height: 1.02;
      }

      .section-lead-grid {
        align-items: start;
      }

      .section-lead {
        min-height: 100%;
        justify-content: center;
      }

      .metric-card {
        padding: 1.15rem 1rem;
      }
    }

    .pill-link:hover {
      background: rgba(255, 255, 255, 0.1);
      color: #fff;
    }

    .grid-noise {
      background-image:
        linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
      background-size: 28px 28px;
      mask-image: radial-gradient(circle at center, black, transparent 82%);
    }

    @keyframes float {
      0%, 100% { transform: translateY(0px); }
      50% { transform: translateY(-10px); }
    }

    .float-slow {
      animation: float 8s ease-in-out infinite;
    }

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

    @media (prefers-reduced-motion: reduce) {
      html {
        scroll-behavior: auto;
      }

      .float-slow {
        animation: none;
      }

      .motion-safe-none {
        transition: none !important;
      }
    }

    @media (max-width: 639px) {
      .site-header {
        display: none !important;
      }

      .site-header {
        padding-top: 0.65rem;
        padding-left: 0.9rem;
        padding-right: 0.9rem;
      }

      .site-header-shell {
        gap: 0.35rem;
        border-radius: 1rem;
        padding: 0.52rem 0.75rem;
      }

      .site-header-brand {
        flex-direction: column;
        align-items: stretch;
        gap: 0.4rem;
      }

      .site-header-copy p:first-child {
        font-size: 0.46rem;
        letter-spacing: 0.22em;
        text-align: center;
      }

      .site-header-copy p:last-child {
        margin-top: 0.12rem;
        max-width: none;
        font-size: 0.64rem;
        line-height: 1.1;
        text-align: center;
      }

      .site-header-cta {
        justify-content: center;
        gap: 0.3rem;
        width: 100%;
        padding: 0.56rem 0.7rem;
        font-size: 0.6rem;
      }

      .hero-section {
        padding-top: 0.8rem;
        padding-bottom: 0.9rem;
      }

      .hero-shell {
        border-radius: 1.35rem;
      }

      .hero-content {
        padding: 1rem;
        padding-top: 1.1rem;
      }

      .section-badge {
        gap: 0.42rem;
        padding: 0.45rem 0.8rem;
        font-size: 0.64rem;
        letter-spacing: 0.22em;
      }

      .hero-title {
        margin-top: 0.7rem;
        font-size: 2.45rem;
        line-height: 0.88;
      }

      .hero-content > p {
        margin-top: 0.75rem;
        font-size: 0.82rem;
        line-height: 1.5;
      }

      .hero-content > .mt-6 {
        margin-top: 0.75rem;
      }

      .hero-content .btn-primary,
      .hero-content .btn-secondary {
        padding: 0.95rem 1.1rem;
        font-size: 0.84rem;
      }

      .hero-content .flex.flex-col.gap-3 {
        gap: 0.65rem;
      }

      .hero-metrics {
        gap: 0.45rem;
      }

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

      .hero-metrics .metric-card {
        padding: 0.42rem 0.42rem;
        border-radius: 0.8rem;
        min-height: 5.45rem;
        gap: 0.2rem;
      }

      .hero-impact-card {
        grid-column: 1 / -1;
        min-width: 0;
        overflow: hidden;
        padding: 0.42rem 0.7rem;
      }

      .hero-impact-text {
        font-size: 0.66rem;
        letter-spacing: 0.08em;
        white-space: nowrap;
      }

      .hero-impact-card p:last-child {
        font-size: 0.42rem;
        letter-spacing: 0.1em;
      }

      .hero-metrics .metric-card p.text-2xl {
        font-size: 1.55rem;
        line-height: 1;
      }

      .hero-metrics .metric-card p.mt-1 {
        margin-top: 0.12rem;
        font-size: 0.42rem;
        letter-spacing: 0.12em;
      }
    }

    @media (min-width: 1024px) {
      .hero-metrics-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }
    }
