  
    :root {
      --white: #ffffff;
      --black: #000000;
      --navy: #090465;
      --navy-strong: #06034a;
      --accent: #a7a6fb;
      --accent-soft: #f4f5ff;
      --text: #15162f;
      --muted: #61647d;
      --line: rgba(9, 4, 101, 0.11);
      --surface: rgba(255, 255, 255, 0.8);
      --shadow-sm: 0 14px 30px rgba(9, 4, 101, 0.08);
      --shadow-md: 0 24px 60px rgba(9, 4, 101, 0.12);
      --shadow-lg: 0 40px 80px rgba(9, 4, 101, 0.16);
      --radius-sm: 14px;
      --radius-md: 18px;
      --radius-lg: 24px;
      --radius-xl: 32px;
      --container: 1240px;
      --ease: 240ms cubic-bezier(0.22, 1, 0.36, 1);
    }

    @font-face {
  font-family: 'Font1';
  src: url('/fonts/MarkGEO-SemiBold.woff2') format('woff2'); /* Super Modern Browsers */
}

@font-face {
  font-family: 'Font2';
  src: url('/fonts/MarkGEOCAPS-Light.woff2') format('woff2'); /* Super Modern Browsers */
}

@font-face {
  font-family: 'Font3';
  src: url('/fonts/MarkGEO-Regular.woff2') format('woff2'); /* Super Modern Browsers */
}


    * {
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      margin: 0;
      font-family: "Font1", sans-serif;
      color: var(--text);
      background:
        radial-gradient(circle at top left, rgba(167, 166, 251, 0.35), transparent 28%),
        radial-gradient(circle at 85% 18%, rgba(9, 4, 101, 0.08), transparent 20%),
        linear-gradient(180deg, #ffffff 0%, #f9faff 52%, #ffffff 100%);
      min-width: 320px;
      overflow-x: hidden;
    }

    body::before,
    body::after {
      content: "";
      position: fixed;
      inset: auto auto 8% -120px;
      width: 260px;
      height: 260px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(167, 166, 251, 0.18), transparent 72%);
      poFont1-events: none;
      filter: blur(8px);
      z-index: -1;
    }

    body::after {
      inset: 12% -110px auto auto;
      width: 300px;
      height: 300px;
      background: radial-gradient(circle, rgba(9, 4, 101, 0.12), transparent 70%);
    }
 h1,h2,h3,h4,h5,h6 { font-family: Font2;}
    img,
    svg {
      display: block;
      max-width: 100%;
    }

    a {
      color: inherit;
      text-decoration: none;
    }

    button,
    input {
      font: inherit;
    }

    button {
      cursor: poFont1;
      border: 0;
      background: none;
      color: inherit;
    }

    .container {
      width: min(calc(100% - 32px), var(--container));
      margin: 0 auto;
    }

    .site-shell {
      position: relative;
      isolation: isolate;
    }

    .site-header {
      position: sticky;
      top: 0;
      z-index: 50;
      backdrop-filter: blur(18px);
      background: rgba(255, 255, 255, 0.78);
      border-bottom: 1px solid rgba(9, 4, 101, 0.08);
      box-shadow: 0 10px 40px rgba(12, 19, 59, 0.05);
    }

    .top-bar {
      border-bottom: 1px solid rgba(9, 4, 101, 0.07);
      background: rgba(248, 249, 255, 0.96);
    }

    .top-bar__inner,
    .mid-bar__inner,
    .nav-bar__inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
    }

    .top-bar__inner {
      min-height: 42px;
      font-size: 0.82rem;
      color: var(--muted);
    }

    .top-bar__note {
      letter-spacing: 0.02em;
      font-weight: 500;
    }

    .lang-switcher {
     display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 50px;
    padding: 0 22px;
    border-radius: 16px;
    font-weight: 700;
    letter-spacing: -0.02em;
    transition: transform var(--ease), box-shadow var(--ease), background var(--ease), color var(--ease), border-color var(--ease);
    white-space: nowrap;
      background: rgba(9, 4, 101, 0.05);
      border-radius: 999px;
      border: 1px solid rgba(9, 4, 101, 0.08);
    }

    .lang-switcher button {
      padding: 12px 12px;
      border-radius: 999px;
      font-size: 0.78rem;
      font-weight: 700;
      color: var(--muted);
      transition: background var(--ease), color var(--ease), transform var(--ease);
    }

    .lang-switcher button.active {
      color: var(--white);
      background: linear-gradient(135deg, var(--navy) 0%, #2a24b0 100%);
      box-shadow: 0 8px 18px rgba(9, 4, 101, 0.2);
    }

    .mid-bar {
      padding: 18px 0;
      border-bottom: 1px solid rgba(9, 4, 101, 0.07);
    }

    .brand {
      display: inline-flex;
      align-items: center;
      gap: 14px;
      min-width: fit-content;
    }

    .brand-mark {
      width: 50px;
      height: 50px;
      border-radius: 18px;
      background:
        linear-gradient(145deg, rgba(167, 166, 251, 0.32), rgba(9, 4, 101, 0.12)),
        var(--white);
      border: 1px solid rgba(9, 4, 101, 0.08);
      display: grid;
      place-items: center;
      box-shadow: var(--shadow-sm);
    }

    .brand-mark span {
      font-size: 1.15rem;
      font-weight: 800;
      color: var(--navy);
      letter-spacing: -0.04em;
    }

    .brand-copy strong {
      display: block;
      font-size: 1.28rem;
      line-height: 1;
      color: var(--navy);
      letter-spacing: -0.04em;
    }

    .brand-copy small {
      display: block;
      margin-top: 5px;
      font-size: 0.82rem;
      color: var(--muted);
      letter-spacing: 0.03em;
      text-transform: uppercase;
    }

    .contact-strip {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 14px;
      flex: 1;
      flex-wrap: wrap;
    }

    .contact-card {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      padding: 11px 14px;
      min-width: 200px;
      background: rgba(255, 255, 255, 0.86);
      border: 1px solid rgba(9, 4, 101, 0.08);
      border-radius: 18px;
      box-shadow: 0 12px 28px rgba(13, 18, 64, 0.05);
      transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
    }

    .contact-card:hover {
      transform: translateY(-2px);
      box-shadow: var(--shadow-sm);
      border-color: rgba(9, 4, 101, 0.14);
    }

    .contact-icon,
    .service-icon,
    .visual-icon,
    .metric-icon {
      width: 42px;
      height: 42px;
      border-radius: 14px;
      display: grid;
      place-items: center;
      flex: none;
      background: linear-gradient(145deg, rgba(167, 166, 251, 0.35), rgba(9, 4, 101, 0.08));
      color: var(--navy);
    }

    .contact-card span,
    .service-card span,
    .visual-card span,
    .metric-card span {
      color: var(--muted);
      font-size: 0.82rem;
      display: block;
      margin-bottom: 4px;
    }

    .contact-card strong,
    .service-card h3,
    .visual-card strong,
    .metric-card strong {
      display: block;
      font-size: 0.96rem;
      letter-spacing: -0.02em;
    }

    .header-actions {
      display: flex;
      align-items: center;
      gap: 12px;
    }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      min-height: 50px;
      padding: 0 22px;
      border-radius: 16px;
      font-weight: 700;
      letter-spacing: -0.02em;
      transition: transform var(--ease), box-shadow var(--ease), background var(--ease), color var(--ease), border-color var(--ease);
      white-space: nowrap;
    }

    .btn:hover {
      transform: translateY(-2px);
    }

    .btn-primary {
      color: var(--white);
      background: #000068;
      box-shadow: 0 18px 38px rgba(9, 4, 101, 0.28);
    }

    .btn-primary:hover {
      box-shadow: 0 22px 46px rgba(9, 4, 101, 0.34);
    }

    .btn-secondary {
      color: var(--navy);
      background: rgba(255, 255, 255, 0.82);
      border: 1px solid rgba(9, 4, 101, 0.12);
      box-shadow: var(--shadow-sm);
    }
  
  
    .nav-bar {
      position: relative;
    }

    .nav-bar__inner {
      min-height: 72px;
    }

    .nav-left {
      position: relative;
      display: flex;
      align-items: center;
      gap: 10px;
      flex: 1;
    }

    .nav-toggle {
      display: none;
      width: 48px;
      height: 48px;
      border-radius: 14px;
      background: rgba(9, 4, 101, 0.05);
      border: 1px solid rgba(9, 4, 101, 0.08);
      color: var(--navy);
      transition: background var(--ease), transform var(--ease);
    }

    .nav-toggle:hover {
      background: rgba(9, 4, 101, 0.1);
    }

    .nav-toggle svg,
    .mega-trigger svg,
    .mega-column-toggle svg {
      width: 20px;
      height: 20px;
    }

    .main-nav {
      display: flex;
      align-items: center;
      gap: 6px;
      width: 100%;
    }

    .nav-link,
    .mega-trigger {
      display: inline-flex;
      font-family: Font2;
      align-items: center;
      gap: 8px;
      padding: 12px 16px;
      border-radius: 14px;
      font-weight: 600;
      color: #25294a;
      transition: color var(--ease), background var(--ease), transform var(--ease);
    }

    .nav-link:hover,
    .mega-trigger:hover {
      background: rgba(9, 4, 101, 0.05);
      color: var(--navy);
    }

    .mega-wrapper {
      position: static;
    }

    .mega-trigger {
      position: relative;
      z-index: 1;
    }

    .mega-trigger.active,
    .mega-trigger[aria-expanded="true"] {
      background: rgba(9, 4, 101, 0.08);
      color: var(--navy);
    }

    .mega-trigger .mega-caret {
      transition: transform 0.25s ease;
    }

    .mega-trigger.active .mega-caret {
      transform: rotate(180deg);
    }

    .mega-panel {
      position: absolute;
      top: calc(100% + 14px);
      left: 0;
      width: 100%;
      padding: 22px;
      border-radius: 24px;
      border: 1px solid rgba(9, 4, 101, 0.08);
      background: rgba(255, 255, 255, 0.98);
      box-shadow: 0 32px 80px rgba(9, 4, 101, 0.14);
      backdrop-filter: blur(18px);
      opacity: 0;
      visibility: hidden;
      transform: translateY(-10px);
      poFont1-events: none;
      transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
    }

    .mega-panel.active {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
      poFont1-events: auto;
    }

    .mega-layout {
      display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 0;
    }

    .mega-column {
      padding: 6px 22px;
    }

    .mega-column + .mega-column {
      border-left: 1px solid rgba(9, 4, 101, 0.08);
    }

    .mega-column--featured {
      margin-left: 18px;
      border-left: 0;
      border-radius: 20px;
      background: linear-gradient(180deg, #f6f7fb 0%, #eef1f8 100%);
    }

    .mega-column-toggle {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 0;
      margin-bottom: 18px;
      color: #15162f;
      font-size: 1rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      cursor: default;
    }

    .mega-column-title {
      display: inline-flex;
      align-items: center;
      gap: 10px;
    }

    .mega-column-toggle .mega-column-caret {
      display: none;
      color: var(--muted);
      transition: transform 0.25s ease;
    }

    .mega-column.active .mega-column-caret {
      transform: rotate(180deg);
    }

    .mega-badge {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 42px;
      height: 24px;
      padding: 0 10px;
      border-radius: 999px;
      background: rgba(167, 166, 251, 0.28);
      color: var(--navy);
      font-size: 0.72rem;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.04em;
    }

    .mega-column-content {
      display: grid;
      gap: 8px;
    }

    .mega-item {
      display: grid;
      grid-template-columns: 40px minmax(0, 1fr);
      align-items: center;
      gap: 12px;
      padding: 12px 14px;
      border-radius: 16px;
      border: 1px solid transparent;
      transition: background 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
    }

    .mega-item:hover {
      background: rgba(167, 166, 251, 0.16);
      border-color: rgba(9, 4, 101, 0.08);
      box-shadow: 0 14px 28px rgba(9, 4, 101, 0.08);
      transform: translateY(-1px);
    }

    .mega-item-icon {
      width: 40px;
      height: 40px;
      border-radius: 14px;
      display: grid;
      place-items: center;
      color: #7a7f9c;
      background: #f7f8fd;
      transition: background 0.25s ease, color 0.25s ease;
    }

    .mega-item:hover .mega-item-icon {
      color: var(--navy);
      background: rgba(255, 255, 255, 0.95);
    }

    .mega-item-icon svg {
      width: 20px;
      height: 20px;
    }

    .mega-item-label {
      color: #1a1c37;
      font-weight: 600;
      line-height: 1.35;
    }

    .hero-copy p,
    .section-head p,
    .service-card p,
    .hero-note p {
      margin: 0;
      color: var(--muted);
      line-height: 1.65;
    }

    .hero {
      position: static;
      padding: 54px 0 38px;
    }

    .hero::before {
      content: "";
      position: absolute;
      inset: 22px 0 auto;
      height: 520px;
      background:
        radial-gradient(circle at 12% 20%, rgba(167, 166, 251, 0.28), transparent 26%),
        radial-gradient(circle at 82% 22%, rgba(9, 4, 101, 0.09), transparent 18%),
        linear-gradient(180deg, rgba(248, 249, 255, 0.65), rgba(255, 255, 255, 0));
      z-index: -1;
      poFont1-events: none;
    }


    .hero-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.92fr);
      gap: 34px;
      align-items: center;
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 9px 14px;
      margin-bottom: 22px;
      border-radius: 999px;
      color: var(--navy);
      font-weight: 700;
      font-size: 0.82rem;
      letter-spacing: 0.03em;
      text-transform: uppercase;
      background: rgba(255, 255, 255, 0.78);
      border: 1px solid rgba(9, 4, 101, 0.08);
      box-shadow: var(--shadow-sm);
    }

    .eyebrow::before {
      content: "";
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: linear-gradient(135deg, var(--navy), var(--accent));
      box-shadow: 0 0 0 5px rgba(167, 166, 251, 0.18);
    }

    .hero-copy h1 {
      margin: 0;
      max-width: 14ch;
      font-size: clamp(2.7rem, 5vw, 5rem);
      line-height: 0.94;
      letter-spacing: -0.07em;
      color: #0f1237;
    }

    .hero-copy p {
      max-width: 62ch;
      margin-top: 22px;
      font-size: 1.05rem;
    }

    .hero-actions {
      display: flex;
      align-items: center;
      gap: 14px;
      margin-top: 32px;
      flex-wrap: wrap;
    }

    .hero-metrics {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 14px;
      margin-top: 38px;
    }

    .metric-card {
      padding: 18px;
      border-radius: 22px;
      border: 1px solid rgba(9, 4, 101, 0.08);
      background: rgba(255, 255, 255, 0.84);
      backdrop-filter: blur(14px);
      box-shadow: var(--shadow-sm);
    }

    .metric-card strong {
      font-size: 1.4rem;
      margin-top: 10px;
      color: var(--navy);
    }
  
  
    .hero-visual {
      position: relative;
      min-height: 610px;
    }

    .visual-shell {
      position: absolute;
      inset: 0;
      padding: 26px;
      border-radius: 34px;
      overflow: hidden;
      background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(247, 248, 255, 0.84)),
        rgba(255, 255, 255, 0.86);
      border: 1px solid rgba(255, 255, 255, 0.6);
      box-shadow: var(--shadow-lg);
      backdrop-filter: blur(18px);
    }

    .visual-shell::before {
      content: "";
      position: absolute;
      inset: 16px;
      border-radius: 28px;
      background:
        radial-gradient(circle at 15% 15%, rgba(167, 166, 251, 0.24), transparent 24%),
        linear-gradient(180deg, rgba(250, 251, 255, 0.9), rgba(245, 246, 255, 0.76));
      border: 1px solid rgba(9, 4, 101, 0.06);
    }

    .visual-shell::after {
      content: "";
      position: absolute;
      inset: auto -80px -100px auto;
      width: 240px;
      height: 240px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(9, 4, 101, 0.12), transparent 66%);
    }

    .visual-grid,
    .visual-card,
    .hero-note {
      position: relative;
      z-index: 1;
    }

    .visual-grid {
      display: grid;
      grid-template-columns: repeat(12, minmax(0, 1fr));
      grid-auto-rows: minmax(50px, auto);
      gap: 14px;
      height: 100%;
    }

    .visual-card {
      border-radius: 26px;
      padding: 20px;
      border: 1px solid rgba(9, 4, 101, 0.08);
      background: rgba(255, 255, 255, 0.84);
      backdrop-filter: blur(16px);
      box-shadow: 0 22px 40px rgba(9, 4, 101, 0.1);
    }

    .visual-card--uptime {
      grid-column: 1 / span 7;
      grid-row: 1 / span 3;
    }

    .visual-card--security {
      grid-column: 8 / span 5;
      grid-row: 1 / span 4;
    }

    .visual-card--cloud {
      grid-column: 1 / span 5;
      grid-row: 4 / span 4;
    }

    .visual-card--flow {
      grid-column: 6 / span 7;
      grid-row: 5 / span 4;
    }

    .visual-card h3,
    .section-head h2 {
      margin: 0 0 12px;
      letter-spacing: -0.05em;
    }

    .visual-card h3 {
      font-size: 1.3rem;
    }

    .visual-card strong {
      margin-top: 14px;
      font-size: 2rem;
      color: var(--navy);
      letter-spacing: -0.06em;
    }

    .mini-bars {
      display: flex;
      align-items: flex-end;
      gap: 10px;
      margin-top: 20px;
      height: 120px;
    }

    .mini-bars span {
      flex: 1;
      margin: 0;
      border-radius: 18px 18px 8px 8px;
      background: linear-gradient(180deg, #bdbcfb 0%, #645ff0 100%);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24);
      animation: rise 1.2s ease-out both;
    }

    .mini-bars span:nth-child(1) { height: 58%; animation-delay: 0.1s; }
    .mini-bars span:nth-child(2) { height: 82%; animation-delay: 0.18s; }
    .mini-bars span:nth-child(3) { height: 74%; animation-delay: 0.26s; }
    .mini-bars span:nth-child(4) { height: 100%; animation-delay: 0.34s; }
    .mini-bars span:nth-child(5) { height: 88%; animation-delay: 0.42s; }

    .security-list,
    .flow-list {
      display: grid;
      gap: 12px;
      margin-top: 20px;
    }

    .security-list div,
    .flow-list div,
    .hero-note,
    .service-card {
      border-radius: 20px;
      border: 1px solid rgba(9, 4, 101, 0.08);
      background: rgba(249, 250, 255, 0.88);
    }

    .security-list div,
    .flow-list div {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 14px 16px;
    }

    .hero-note {
      position: absolute;
      right: -10px;
      bottom: 26px;
      max-width: 245px;
      padding: 18px;
      background: rgba(255, 255, 255, 0.9);
      backdrop-filter: blur(18px);
      box-shadow: var(--shadow-md);
    }

    .hero-note strong {
      display: block;
      margin-bottom: 8px;
      color: var(--navy);
      letter-spacing: -0.03em;
    }

    .services {
      padding: 58px 0 92px;
    }

    .section-head {
      display: flex;
      align-items: end;
      justify-content: space-between;
      gap: 18px;
      margin-bottom: 28px;
    }

    .section-head h2 {
      max-width: 10ch;
      font-size: clamp(2rem, 4vw, 3.3rem);
      line-height: 0.98;
      color: #111433;
    }

    .section-head p {
      max-width: 54ch;
      font-size: 1rem;
    }

    .services-track {
      display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 16px;
    }

    .service-card {
      padding: 24px;
      min-height: 265px;
      box-shadow: 0 18px 36px rgba(9, 4, 101, 0.07);
      transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease), background var(--ease);
      position: relative;
      overflow: hidden;
    }

    .service-card::after {
      content: "";
      position: absolute;
      inset: auto -40px -60px auto;
      width: 140px;
      height: 140px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(167, 166, 251, 0.16), transparent 70%);
      opacity: 0;
      transition: opacity var(--ease);
    }

    .service-card:hover {
      transform: translateY(-8px);
      box-shadow: var(--shadow-md);
      border-color: rgba(9, 4, 101, 0.14);
      background: rgba(255, 255, 255, 0.95);
    }

    .service-card:hover::after {
      opacity: 1;
    }

    .service-card h3 {
      margin: 18px 0 12px;
      font-size: 1.2rem;
      color: #14183d;
      letter-spacing: -0.04em;
    }

    .service-card .service-tag {
      display: inline-flex;
      align-items: center;
      margin-top: 18px;
      padding: 9px 12px;
      border-radius: 999px;
      font-size: 0.82rem;
      font-weight: 700;
      color: var(--navy);
      background: rgba(167, 166, 251, 0.16);
    }

    .fade-up {
      opacity: 0;
      transform: translateY(22px);
      animation: fadeUp 0.8s var(--ease) forwards;
    }

    .delay-1 { animation-delay: 0.08s; }
    .delay-2 { animation-delay: 0.16s; }
    .delay-3 { animation-delay: 0.24s; }
    .delay-4 { animation-delay: 0.32s; }
    .delay-5 { animation-delay: 0.4s; }

    .modal {
      position: fixed;
      inset: 0;
      display: grid;
      place-items: center;
      padding: 18px;
      background: rgba(9, 4, 101, 0.34);
      backdrop-filter: blur(16px);
      opacity: 0;
      visibility: hidden;
      poFont1-events: none;
      transition: opacity var(--ease), visibility var(--ease);
      z-index: 90;
    }

    .modal.is-open {
      opacity: 1;
      visibility: visible;
      poFont1-events: auto;
    }

    .modal-panel {
      width: min(100%, 460px);
      padding: 30px;
      border-radius: 30px;
      background:
        radial-gradient(circle at top left, rgba(167, 166, 251, 0.18), transparent 26%),
        rgba(255, 255, 255, 0.96);
      border: 1px solid rgba(255, 255, 255, 0.7);
      box-shadow: 0 34px 90px rgba(9, 4, 101, 0.24);
      transform: translateY(18px) scale(0.96);
      opacity: 0;
      transition: transform var(--ease), opacity var(--ease);
    }

    .modal.is-open .modal-panel {
      transform: translateY(0) scale(1);
      opacity: 1;
    }
  
  
    .modal-head {
      display: flex;
      align-items: start;
      justify-content: space-between;
      gap: 18px;
      margin-bottom: 22px;
    }

    .modal-head h2 {
      margin: 0 0 8px;
      font-size: 1.9rem;
      letter-spacing: -0.06em;
      color: #13183d;
    }

    .modal-head p {
      margin: 0;
      color: var(--muted);
      line-height: 1.6;
    }

    .modal-close {
      width: 42px;
      height: 42px;
      border-radius: 14px;
      background: rgba(9, 4, 101, 0.06);
      border: 1px solid rgba(9, 4, 101, 0.08);
      color: var(--navy);
      transition: background var(--ease), transform var(--ease);
    }

    .modal-close:hover {
      background: rgba(9, 4, 101, 0.1);
      transform: rotate(90deg);
    }

    .tabs {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      padding: 5px;
      margin-bottom: 22px;
      background: rgba(9, 4, 101, 0.05);
      border-radius: 18px;
      border: 1px solid rgba(9, 4, 101, 0.08);
    }

    .tab-btn {
      min-height: 46px;
      border-radius: 14px;
      font-weight: 700;
      color: var(--muted);
      transition: background var(--ease), color var(--ease), box-shadow var(--ease);
    }

    .tab-btn.active {
      color: var(--navy);
      background: var(--white);
      box-shadow: 0 12px 24px rgba(9, 4, 101, 0.08);
    }

    .auth-panel {
      display: none;
    }

    .auth-panel.active {
      display: block;
    }

    .form-grid {
      display: grid;
      gap: 16px;
    }

    .field {
      display: grid;
      gap: 8px;
    }

    .field label {
      font-size: 0.9rem;
      font-weight: 600;
      color: #21254a;
    }

    .field input {
      width: 100%;
      min-height: 54px;
      padding: 0 16px;
      border-radius: 16px;
      border: 1px solid rgba(9, 4, 101, 0.12);
      background: rgba(255, 255, 255, 0.88);
      outline: none;
      transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
    }

    .field input:focus {
      border-color: rgba(9, 4, 101, 0.28);
      box-shadow: 0 0 0 5px rgba(167, 166, 251, 0.2);
      background: var(--white);
    }

    .form-meta {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      font-size: 0.88rem;
      color: var(--muted);
    }

    .form-meta a {
      color: var(--navy);
      font-weight: 700;
    }

    .auth-submit {
      width: 100%;
      margin-top: 6px;
    }

    .auth-footnote {
      margin-top: 16px;
      font-size: 0.84rem;
      color: var(--muted);
      text-align: center;
    }

    .sr-only {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }

    @keyframes fadeUp {
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

    @keyframes rise {
      from {
        transform: scaleY(0.35);
        transform-origin: bottom;
        opacity: 0.35;
      }
      to {
        transform: scaleY(1);
        transform-origin: bottom;
        opacity: 1;
      }
    }

    @media (max-width: 1160px) {
      .contact-strip { justify-content: flex-start; }
      .hero-grid { grid-template-columns: 1fr; }
      .services-track { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .hero-visual { min-height: 560px; }
      .mega-layout { grid-template-columns: repeat(3, minmax(0, 1fr)); }
      .mega-column--featured {
        grid-column: span 3;
        margin: 18px 0 0;
      }
      .mega-column:nth-child(4) {
        border-left: 0;
      }
    }

    @media (max-width: 980px) {
      .mid-bar__inner { align-items: start; flex-wrap: wrap; }
      .header-actions { width: 100%; justify-content: flex-end; }
      .nav-toggle { display: inline-grid; place-items: center; }
      .nav-bar__inner { align-items: center; }
      .main-nav {
        position: absolute;
        top: calc(100% + 10px);
        left: 16px;
        right: 16px;
        display: grid;
        gap: 10px;
        padding: 16px;
        border-radius: 24px;
        background: rgba(255, 255, 255, 0.96);
        border: 1px solid rgba(9, 4, 101, 0.08);
        box-shadow: var(--shadow-lg);
        opacity: 0;
        transform: translateY(10px);
        visibility: hidden;
        poFont1-events: none;
        transition: opacity var(--ease), transform var(--ease), visibility var(--ease);
      }
      .main-nav.is-open {
        opacity: 1;
        transform: translateY(0);
        visibility: visible;
        poFont1-events: auto;
      }
      .nav-link,
      .mega-trigger { width: 100%; justify-content: space-between; }
      .mega-trigger.active {
        background: rgba(9, 4, 101, 0.08);
      }
      .mega-panel {
        position: static;
        width: 100%;
        margin-top: 8px;
        padding: 12px 0 0;
        border: 0;
        border-top: 1px solid rgba(9, 4, 101, 0.08);
        border-radius: 0;
        box-shadow: none;
        backdrop-filter: none;
        background: transparent;
        opacity: 1;
        visibility: hidden;
        transform: none;
        poFont1-events: none;
        display: none;
      }
      .mega-panel.active {
        display: block;
        visibility: visible;
        poFont1-events: auto;
      }
      .mega-layout {
        grid-template-columns: 1fr;
        gap: 10px;
      }
      .mega-column,
      .mega-column--featured {
        margin: 0;
        padding: 0;
        border-left: 0;
        border-radius: 18px;
        background: rgba(248, 249, 255, 0.8);
      }
      .mega-column + .mega-column {
        border-left: 0;
      }
      .mega-column-toggle {
        padding: 16px 18px;
        margin-bottom: 0;
        cursor: poFont1;
      }
      .mega-column-toggle .mega-column-caret {
        display: block;
      }
      .mega-column-content {
        max-height: 0;
        overflow: hidden;
        padding: 0 12px;
        transition: max-height 0.25s ease, padding 0.25s ease;
      }
      .mega-column.active .mega-column-content {
        max-height: 560px;
        padding: 0 12px 12px;
      }
      .hero { padding-top: 34px; }
      .hero-grid { gap: 24px; }
      .hero-copy h1 { max-width: none; }
      .hero-visual { min-height: 680px; }
    }

    @media (max-width: 720px) {
      .container { width: min(calc(100% - 24px), var(--container)); }
      .top-bar__inner,
      .mid-bar__inner { gap: 14px; }
      .top-bar__inner {
        min-height: 48px;
        flex-wrap: wrap;
        justify-content: center;
        padding: 8px 0;
        text-align: center;
      }
      .mid-bar { padding: 16px 0; }
      .brand,
      .contact-strip,
      .header-actions { width: 100%; }
      .contact-card { width: 100%; min-width: 0; }
      .header-actions { justify-content: stretch; }
      .header-actions .btn { width: 100%; }
      .nav-bar__inner { min-height: 66px; }
      .hero-copy p,
      .section-head p { font-size: 0.98rem; }
      .hero-actions {
        display: grid;
        grid-template-columns: 1fr;
      }
      .hero-actions .btn { width: 100%; }
      .hero-metrics { grid-template-columns: 1fr; }
      .hero-visual { min-height: auto; }
      .visual-shell {
        position: relative;
        inset: auto;
        min-height: 650px;
      }
      .visual-grid { grid-auto-rows: auto; }
      .visual-card--uptime,
      .visual-card--security,
      .visual-card--cloud,
      .visual-card--flow {
        grid-column: 1 / -1;
        grid-row: auto;
      }
      .hero-note {
        position: relative;
        right: auto;
        bottom: auto;
        max-width: none;
        margin-top: 16px;
      }
      .section-head {
        align-items: start;
        flex-direction: column;
      }
      .section-head h2 { max-width: none; }
      .services-track {
        display: grid;
        grid-auto-flow: column;
        grid-auto-columns: minmax(82%, 1fr);
        overflow-x: auto;
        padding-bottom: 8px;
        scroll-snap-type: x proximity;
        scrollbar-width: thin;
      }
      .service-card {
        min-height: 240px;
        scroll-snap-align: start;
      }
      .modal-panel {
        padding: 24px 18px;
        border-radius: 24px;
      }
      .modal-head { align-items: center; }
      .modal-head h2 { font-size: 1.6rem; }
      .form-meta {
        align-items: start;
        flex-direction: column;
      }
    }
  

    .cn-experience {
  padding: 80px 20px;
  background: #f8f9ff;
  font-family: 'Font1', sans-serif;
}

.cn-container {
  max-width: 1200px;
  margin: auto;
}

.cn-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px;
}

.cn-header h2 {
  font-size: 32px;
  color: #000;
  margin-bottom: 10px;
}

.cn-header p {
  color: #555;
  max-width: 600px;
}

.cn-btn {
  background: #090465;
  color: #fff;
  padding: 12px 22px;
  border-radius: 10px;
  text-decoration: none;
  transition: 0.3s;
}

.cn-btn:hover {
  background: #a7a6fb;
  color: #000;
}

.cn-content {
  display: flex;
  gap: 40px;
  align-items: center;
}

.cn-features {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  flex: 1;
}

.cn-card {
  display: flex;
  align-items: center;
  gap: 15px;
  background: #fff;
  padding: 20px;
  border-radius: 16px;
  transition: 0.3s;
  box-shadow: 0 5px 20px rgba(0,0,0,0.05);
}

.cn-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
}

.cn-icon {
  width: 45px;
  height: 45px;
  background: #a7a6fb;
  color: #090465;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  font-size: 20px;
}

.cn-image img {
  width: 100%;
  border-radius: 20px;
}

/* MOBILE */
@media (max-width: 900px) {
  .cn-content {
    flex-direction: column;
  }

  .cn-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
  }
}


.cn-section {
  padding: 90px 20px;
  background: #f8f9ff;
}

.cn-section.alt {
  background: #ffffff;
}

.cn-container {
  max-width: 1200px;
  margin: auto;
}

.cn-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 50px;
}

.cn-head h2 {
  font-size: 34px;
  color: #000;
  margin-bottom: 10px;
}

.cn-head p {
  color: #555;
  max-width: 600px;
}

.cn-btn {
  background: linear-gradient(135deg, #090465, #a7a6fb);
  color: #fff;
  padding: 12px 24px;
  border-radius: 12px;
  text-decoration: none;
  transition: 0.3s;
}

.cn-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(9,4,101,0.3);
}

.cn-grid {
  display: flex;
  gap: 50px;
  align-items: center;
}

.cn-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  flex: 1;
}

.cn-card {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 22px;
  border-radius: 18px;
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
  transition: 0.3s;
}

.cn-card i {
  font-size: 20px;
  color: #090465;
  background: #a7a6fb;
  padding: 12px;
  border-radius: 12px;
}

.cn-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 50px rgba(0,0,0,0.1);
}

.cn-visual img {
  width: 100%;
  border-radius: 24px;
}

/* MOBILE */
@media (max-width: 900px) {
  .cn-grid {
    flex-direction: column;
  }

  .cn-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
  }
}

.rs-footer {
  background: #000068;
  color: #fff;
  padding: 60px 20px 30px;
  font-family: 'Font1', sans-serif;
}

.rs-container {
  max-width: 1200px;
  margin: auto;
  display: flex;
  gap: 60px;
}

.rs-left {
  width: 320px;
}

.rs-left h2 {
  font-size: 22px;
  margin-bottom: 15px;
}

.rs-badge {
  display: inline-block;
  background: #a5a5ff;
  padding: 6px 12px;
  border-radius: 8px;
  margin-bottom: 20px;
  font-size: 12px;
}

.rs-left h3 {
  margin: 20px 0 10px;
}

.rs-socials a {
  display: inline-flex;
  width: 36px;
  height: 36px;
  background: #a5a5ff;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  margin-right: 8px;
  color: #fff;
}

.rs-apps i {
  font-size: 22px;
  margin-right: 10px;
}

.rs-google {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #a5a5ff;
  padding: 10px;
  border-radius: 10px;
  margin-top: 10px;
}

.rs-google img {
  width: 25px;
}

.rs-badges img {
  width: 50px;
  margin: 5px;
}

.rs-columns {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

.rs-col h4 {
  color: #fff;
  margin-bottom: 10px;
}

.rs-col a {
  display: block;
  margin: 6px 0;
  color: #9fb8c1;
  text-decoration: none;
  transition: 0.3s;
}

.rs-col a:hover {
  color: #fff;
}

.new {
  background: #00c389;
  color: #fff;
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 6px;
  margin-left: 5px;
}

.rs-bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  margin-top: 40px;
  padding-top: 20px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.rs-links a {
  margin-left: 15px;
  color: #9fb8c1;
  text-decoration: none;
}

.rs-links a:hover {
  color: #fff;
}

/* MOBILE */
@media (max-width: 900px) {
  .rs-container {
    flex-direction: column;
  }

  .rs-columns {
    grid-template-columns: repeat(2, 1fr);
  }
}

.cn-container{max-width:1200px;margin:auto;padding:20px}
.cn-btn{background:#090465;color:#fff;padding:12px 20px;border-radius:10px;text-decoration:none}
.cn-about-grid,.cn-contact-grid{display:flex;gap:40px;align-items:center}
.cn-reviews-grid,.cn-blog-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cn-review,.cn-post{background:#fff;padding:20px;border-radius:16px;box-shadow:0 5px 20px rgba(0,0,0,.05)}
.cn-contact-form input,.cn-contact-form textarea{width:100%;margin-bottom:10px;padding:12px;border-radius:10px;border:1px solid #ddd}
.cn-contact-form button{background:#090465;color:#fff;padding:12px;border:none;border-radius:10px}

/* Codex Section Upgrade */
.codex {
  position: relative;
  padding: clamp(72px, 8vw, 112px) 0;
  overflow: clip;
}

.codex::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 12% 18%, rgba(167, 166, 251, 0.16), transparent 28%),
    radial-gradient(circle at 88% 22%, rgba(9, 4, 101, 0.08), transparent 18%);
  opacity: 0.9;
}

.codex > .cn-container:not(.codex-upgrade) {
  display: none;
}

.codex > .cn-container.codex-upgrade {
  position: relative;
  z-index: 1;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 20px;
}

.codex-analytics,
.codex-about,
.codex-contact {
  background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
}

.codex-sales,
.codex-reviews,
.codex-blog,
.codex-experience {
  background: linear-gradient(180deg, #f7f9ff 0%, #ffffff 100%);
}

.codex-shell,
.codex-sales-grid,
.cn-contact.codex .cn-contact-grid {
  display: grid;
  gap: 28px;
}

.codex-shell--split,
.codex-shell--about {
  grid-template-columns: minmax(0, 1.02fr) minmax(340px, 0.98fr);
  align-items: center;
}

.codex-shell--experience,
.codex-sales-grid,
.cn-contact.codex .cn-contact-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
}

.codex-stack-head,
.codex-review-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 34px;
}

.codex-copy h2,
.codex-review-head h2 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
  color: #101430;
  max-width: 13ch;
}

.codex-copy p,
.codex-review-head p,
.codex-panel p,
.codex-point p,
.codex-feature-card p,
.codex-board-card p,
.cn-review p,
.cn-post p,
.codex-contact-card small,
.codex-form-intro p,
.codex-promise-grid span {
  margin: 0;
  color: var(--muted);
  line-height: 1.68;
  font-size: 0.98rem;
}

.codex-copy {
  display: grid;
  gap: 18px;
}

.codex-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  padding: 9px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(9, 4, 101, 0.1);
  box-shadow: 0 14px 28px rgba(9, 4, 101, 0.08);
  color: var(--navy);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.codex-kicker::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--navy), var(--accent));
  box-shadow: 0 0 0 5px rgba(167, 166, 251, 0.18);
}

.codex-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.codex .cn-btn,
.codex .cn-contact-form button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 24px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--navy) 0%, #1c1797 68%, #4f47eb 100%);
  color: #fff;
  font-weight: 700;
  box-shadow: 0 18px 38px rgba(9, 4, 101, 0.24);
  transition: transform var(--ease), box-shadow var(--ease), filter var(--ease);
}

.codex .cn-btn:hover,
.codex .cn-contact-form button:hover {
  transform: translateY(-3px);
  box-shadow: 0 24px 48px rgba(9, 4, 101, 0.3);
  filter: saturate(1.05);
}

.codex-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--navy);
  font-weight: 700;
}

.codex-link::after {
  content: "→";
  transition: transform var(--ease);
}

.codex-link:hover::after {
  transform: translateX(4px);
}

.codex-point-list,
.codex-mini-panels,
.codex-chip-grid,
.codex-bullet-list,
.codex-contact-cards,
.codex-promise-grid {
  display: grid;
  gap: 14px;
}

.codex-point,
.codex-panel,
.codex-feature-card,
.codex-chip,
.codex-capability,
.cn-review,
.cn-post,
.codex-contact-card,
.codex-promise-grid div,
.cn-contact.codex .cn-contact-form {
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(9, 4, 101, 0.08);
  border-radius: 22px;
  box-shadow: 0 18px 38px rgba(9, 4, 101, 0.08);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease), background var(--ease);
}

.codex-point:hover,
.codex-panel:hover,
.codex-feature-card:hover,
.codex-chip:hover,
.codex-capability:hover,
.cn-review:hover,
.cn-post:hover,
.codex-contact-card:hover,
.codex-promise-grid div:hover {
  transform: translateY(-6px);
  box-shadow: 0 26px 50px rgba(9, 4, 101, 0.12);
  border-color: rgba(9, 4, 101, 0.16);
  background: rgba(255, 255, 255, 0.98);
}

.codex-point {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 16px;
  padding: 20px;
}

.codex-point h3,
.codex-feature-card h3,
.cn-contact.codex .cn-contact-form h3,
.cn-post h3 {
  margin: 0 0 8px;
  color: #14183d;
  letter-spacing: -0.03em;
}

.codex-point-icon,
.codex-feature-card i,
.codex-contact-card i,
.codex-chip i {
  width: 46px;
  height: 46px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  background: linear-gradient(145deg, rgba(167, 166, 251, 0.32), rgba(9, 4, 101, 0.08));
  color: var(--navy);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.codex-dashboard {
  display: grid;
  gap: 16px;
}

.codex-panel {
  padding: 22px;
}

.codex-panel span,
.codex-board-card small,
.codex-capability small,
.codex-contact-card small,
.codex-post-tag,
.codex-panel-head span {
  display: block;
  margin-bottom: 8px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 600;
}

.codex-panel strong,
.codex-capability strong,
.codex-contact-card strong,
.codex-panel-head strong {
  display: block;
  color: var(--navy);
  letter-spacing: -0.04em;
}

.codex-panel--hero {
  padding: 26px;
  background:
    radial-gradient(circle at top right, rgba(167, 166, 251, 0.22), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 248, 255, 0.92));
}

.codex-panel-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 18px;
}

.codex-panel-head strong {
  font-size: 2rem;
}

.codex-bars {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  height: 120px;
  margin: 24px 0;
}

.codex-bars span {
  flex: 1;
  border-radius: 16px 16px 8px 8px;
  background: linear-gradient(180deg, #cac9ff 0%, #6e69f2 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

.codex-bars span:nth-child(1) { height: 54%; }
.codex-bars span:nth-child(2) { height: 78%; }
.codex-bars span:nth-child(3) { height: 66%; }
.codex-bars span:nth-child(4) { height: 100%; }
.codex-bars span:nth-child(5) { height: 86%; }

.codex-inline-stats,
.codex-mini-panels,
.codex-capability-grid,
.codex-feature-grid,
.cn-reviews.codex .cn-reviews-grid,
.cn-blog.codex .cn-blog-grid {
  display: grid;
  gap: 16px;
}

.codex-inline-stats {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.codex-inline-stats div {
  padding-top: 14px;
  border-top: 1px solid rgba(9, 4, 101, 0.08);
}

.codex-inline-stats small {
  display: block;
  margin-bottom: 6px;
  color: var(--muted);
}

.codex-inline-stats strong {
  font-size: 1.3rem;
}

.codex-mini-panels,
.codex-capability-grid,
.codex-feature-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.codex-feature-card,
.codex-capability {
  padding: 22px;
}

.codex-feature-card i {
  margin-bottom: 18px;
}

.codex-process {
  display: grid;
  gap: 16px;
}

.codex-process-step,
.codex-proof-strip,
.codex-contact-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 16px;
  padding: 22px;
}

.codex-process-step strong {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: rgba(167, 166, 251, 0.18);
  color: var(--navy);
  font-size: 1.05rem;
}

.codex-process-step h3,
.codex-board-card strong,
.codex-capability strong,
.codex-contact-card strong,
.cn-review span {
  margin: 0 0 6px;
  font-size: 1.05rem;
}

.codex-ops-board {
  padding: 28px;
  border-radius: 30px;
  color: #fff;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.16), transparent 30%),
    linear-gradient(160deg, #090465 0%, #171093 58%, #4b43df 100%);
  box-shadow: 0 32px 70px rgba(9, 4, 101, 0.22);
}

.codex-board-top {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 22px;
}

.codex-board-top span {
  color: rgba(255, 255, 255, 0.72);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.76rem;
}

.codex-board-top strong {
  font-size: 1.5rem;
  letter-spacing: -0.04em;
}

.codex-board-grid {
  display: grid;
  gap: 14px;
}

.codex-board-card {
  padding: 18px 20px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(8px);
}

.codex-board-card strong {
  display: block;
  color: #fff;
  font-size: 1.8rem;
}

.codex-board-card p,
.codex-board-card small {
  color: rgba(255, 255, 255, 0.74);
}

.codex-board-card--primary {
  background: rgba(255, 255, 255, 0.16);
}

.codex-chip-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.codex-chip {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
}

.codex-bullet-list {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}

.codex-bullet-list div {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #1a1c37;
  font-weight: 600;
}

.codex-bullet-list i {
  color: var(--navy);
}

.codex-review-head {
  margin-bottom: 24px;
}

.codex-proof-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 20px;
  background: rgba(255, 255, 255, 0.92);
}

.codex-proof-strip div {
  display: grid;
  gap: 6px;
}

.codex-proof-strip strong {
  font-size: 1.65rem;
  color: var(--navy);
}

.cn-reviews.codex .cn-reviews-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cn-review {
  padding: 24px;
}

.codex-stars {
  margin-bottom: 14px;
  color: #f4b400;
  letter-spacing: 0.16em;
}

.cn-review span {
  display: block;
  color: #1a1c37;
  font-weight: 600;
  margin-top: 18px;
}

.codex-contact-cards {
  margin-top: 8px;
}

.codex-contact-card {
  align-items: center;
}

.codex-promise-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 8px;
}

.codex-promise-grid div {
  padding: 20px;
}

.codex-promise-grid strong {
  display: block;
  margin-bottom: 6px;
  color: #14183d;
}

.cn-contact.codex .cn-contact-form {
  padding: 26px;
}

.cn-contact.codex .cn-contact-form input,
.cn-contact.codex .cn-contact-form textarea {
  width: 100%;
  padding: 15px 16px;
  margin: 0 0 12px;
  border-radius: 16px;
  border: 1px solid rgba(9, 4, 101, 0.12);
  background: rgba(248, 250, 255, 0.82);
  outline: none;
  transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
}

.cn-contact.codex .cn-contact-form input:focus,
.cn-contact.codex .cn-contact-form textarea:focus {
  border-color: rgba(9, 4, 101, 0.26);
  box-shadow: 0 0 0 5px rgba(167, 166, 251, 0.16);
  background: #fff;
}

.cn-contact.codex .cn-contact-form textarea {
  min-height: 150px;
  resize: vertical;
}

.codex-post-tag {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(167, 166, 251, 0.18);
  color: var(--navy);
  margin-bottom: 18px;
}

.cn-blog.codex .cn-blog-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cn-post {
  padding: 24px;
}

.cn-post .codex-link {
  margin-top: 18px;
}

.codex .cn-container.codex-upgrade > * {
  animation: codexEnter 0.8s var(--ease) both;
}

@keyframes codexEnter {
  from {
    opacity: 0;
    transform: translateY(22px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 1100px) {
  .codex-shell--split,
  .codex-shell--about,
  .codex-shell--experience,
  .codex-sales-grid,
  .cn-contact.codex .cn-contact-grid {
    grid-template-columns: 1fr;
  }

  .codex-mini-panels,
  .codex-capability-grid,
  .codex-feature-grid,
  .cn-reviews.codex .cn-reviews-grid,
  .cn-blog.codex .cn-blog-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .codex-stack-head,
  .codex-review-head {
    align-items: start;
    flex-direction: column;
  }

  .codex-copy h2,
  .codex-review-head h2 {
    max-width: none;
  }
}

@media (max-width: 760px) {
  .codex {
    padding: 72px 0;
  }

  .codex > .cn-container.codex-upgrade {
    padding: 0 16px;
  }

  .codex-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .codex-actions .cn-btn,
  .codex-actions .codex-link {
    width: 100%;
    justify-content: center;
  }

  .codex-inline-stats,
  .codex-mini-panels,
  .codex-capability-grid,
  .codex-feature-grid,
  .cn-reviews.codex .cn-reviews-grid,
  .cn-blog.codex .cn-blog-grid,
  .codex-chip-grid,
  .codex-proof-strip,
  .codex-promise-grid {
    grid-template-columns: 1fr;
  }

  .codex-point,
  .codex-process-step,
  .codex-contact-card {
    grid-template-columns: 1fr;
  }

  .codex-point-icon,
  .codex-feature-card i,
  .codex-contact-card i {
    margin-bottom: 4px;
  }

  .codex-panel-head,
  .codex-board-top {
    align-items: start;
    flex-direction: column;
  }

  .codex-proof-strip {
    margin-bottom: 16px;
  }
}

.cn-profile {
  padding: 60px 20px;
  background: #f8f9ff;
  font-family: Font1;
}

.cn-container {
  max-width: 1000px;
  margin: auto;
}

.cn-tabs {
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
}

.cn-tabs button {
  padding: 10px 18px;
  border: none;
  border-radius: 10px;
  background: #eee;
  cursor: pointer;
}

.cn-tabs .active {
  background: #090465;
  color: #fff;
}

.cn-number-box {
  background: #fff;
  padding: 20px;
  border-radius: 16px;
  margin-bottom: 20px;
}

.cn-number {
  font-size: 24px;
  font-weight: bold;
}

.cn-actions {
  margin-top: 10px;
  display: flex;
  gap: 15px;
  flex-wrap: wrap;
}

.cn-btn {
  background: #090465;
  color: #fff;
  padding: 10px 18px;
  border-radius: 10px;
  text-decoration: none;
  border: none;
}

.cn-link {
  color: #090465;
  text-decoration: none;
}

.cn-invoices, .cn-package {
  background: #fff;
  padding: 20px;
  border-radius: 16px;
  margin-bottom: 20px;
}

.cn-invoice {
  padding: 10px;
  border-bottom: 1px solid #eee;
}

.cn-package-box {
  padding: 15px;
  background: #a7a6fb;
  border-radius: 12px;
  color: #000;
}

/* MODAL */
.cn-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  justify-content: center;
  align-items: center;
}

.cn-modal-box {
  background: #fff;
  padding: 25px;
  border-radius: 16px;
  width: 300px;
}

.cn-payments span {
  display: inline-block;
  margin: 5px;
  padding: 6px 10px;
  background: #eee;
  border-radius: 6px;
}

.cn-profile-legacy {
  display: none !important;
}

.cn-modal-legacy {
  display: none !important;
}

.cn-profile {
  position: relative;
  padding: clamp(48px, 6vw, 88px) 20px 72px;
  background:
    radial-gradient(circle at top left, rgba(121, 140, 255, 0.1), transparent 26%),
    radial-gradient(circle at top right, rgba(15, 23, 42, 0.06), transparent 22%),
    #ffffff;
  font-family: "Font1", "Font1", sans-serif;
}

.cn-dashboard-shell {
  width: min(100%, 1200px);
  margin: 0 auto;
  display: grid;
  gap: 24px;
}

.cn-company-card,
.cn-surface-card,
.cn-tab-card,
.cn-modal-box {
  position: relative;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 24px;
  box-shadow: 0 18px 44px rgba(15, 23, 42, 0.08);
}

.cn-company-card {
  overflow: hidden;
  padding: 28px;
}

.cn-company-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 90% 0%, rgba(80, 120, 255, 0.12), transparent 28%),
    linear-gradient(135deg, rgba(248, 250, 255, 0.94), rgba(255, 255, 255, 0.98));
  pointer-events: none;
}

.cn-company-card__head,
.cn-company-meta,
.cn-card-head,
.cn-number-grid,
.cn-ticket-list,
.cn-number-actions {
  position: relative;
  z-index: 1;
}

.cn-company-card__head,
.cn-card-head,
.cn-number-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.cn-section-kicker {
  margin: 0 0 10px;
  color: #5b6475;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.cn-company-card h1,
.cn-card-head h2,
.cn-ticket-item h3,
.cn-modal-box h3 {
  margin: 0;
  color: #0f172a;
  letter-spacing: -0.04em;
}

.cn-company-card h1 {
  font-size: clamp(2rem, 4vw, 2.8rem);
}

.cn-status-chip,
.cn-card-badge,
.cn-table-status,
.cn-ticket-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
}

.cn-status-chip {
  color: #0f766e;
  background: rgba(20, 184, 166, 0.12);
  border: 1px solid rgba(20, 184, 166, 0.18);
}

.cn-status-chip .material-symbols-outlined,
.cn-tab-card__icon,
.cn-meta-card__icon,
.cn-number-card__icon {
  font-variation-settings: "FILL" 1, "wght" 500, "GRAD" 0, "opsz" 24;
}

.cn-company-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}

.cn-meta-card {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  padding: 18px;
  border-radius: 20px;
  background: rgba(248, 250, 252, 0.92);
  border: 1px solid rgba(148, 163, 184, 0.18);
}

.cn-meta-card__icon,
.cn-number-card__icon {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  color: #1034a6;
  background: linear-gradient(135deg, rgba(73, 103, 255, 0.14), rgba(15, 23, 42, 0.06));
}

.cn-meta-card__label,
.cn-tab-card__label {
  display: block;
  margin-bottom: 6px;
  color: #667085;
  font-size: 0.84rem;
  font-weight: 600;
}

.cn-meta-card strong,
.cn-number-card strong {
  font-size: 1.05rem;
  color: #0f172a;
}

.cn-tabs-panel {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.cn-tab-card {
  display: grid;
  gap: 10px;
  padding: 20px;
  text-align: left;
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease), background var(--ease);
}

.cn-tab-card:hover,
.cn-surface-card:hover,
.cn-number-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 52px rgba(15, 23, 42, 0.12);
}

.cn-tab-card.active {
  border-color: rgba(37, 99, 235, 0.24);
  box-shadow: 0 24px 58px rgba(37, 99, 235, 0.16);
}

.cn-tab-card strong {
  font-size: 1.7rem;
  color: #0f172a;
  letter-spacing: -0.05em;
}

.cn-tab-card__icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  font-size: 1.35rem;
}

.cn-tab-card.is-balance {
  background: linear-gradient(180deg, rgba(240, 249, 255, 0.96), rgba(255, 255, 255, 0.96));
}

.cn-tab-card.is-balance .cn-tab-card__icon {
  color: #0f62fe;
  background: rgba(14, 116, 255, 0.12);
}

.cn-tab-card.is-debt {
  background: linear-gradient(180deg, rgba(254, 242, 242, 0.96), rgba(255, 255, 255, 0.96));
}

.cn-tab-card.is-debt .cn-tab-card__icon {
  color: #dc2626;
  background: rgba(220, 38, 38, 0.12);
}

.cn-tab-card.is-invoices {
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.96), rgba(255, 255, 255, 0.96));
}

.cn-tab-card.is-invoices .cn-tab-card__icon {
  color: #475467;
  background: rgba(100, 116, 139, 0.12);
}

.cn-tab-card.is-operator {
  background: linear-gradient(180deg, rgba(240, 253, 244, 0.96), rgba(255, 255, 255, 0.96));
}

.cn-tab-card.is-operator .cn-tab-card__icon {
  color: #16a34a;
  background: rgba(22, 163, 74, 0.12);
}

.cn-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.82fr) minmax(0, 1.18fr);
  gap: 24px;
}

.cn-surface-card {
  padding: 24px;
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}

.cn-card-head {
  margin-bottom: 18px;
}

.cn-card-head h2 {
  font-size: 1.35rem;
}

.cn-card-badge {
  color: #334155;
  background: rgba(148, 163, 184, 0.14);
}

.cn-ticket-list,
.cn-number-grid {
  display: grid;
  gap: 14px;
}

.cn-ticket-item,
.cn-number-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(148, 163, 184, 0.16);
  background: #fbfdff;
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}

.cn-ticket-item {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.cn-ticket-item h3 {
  font-size: 1rem;
}

.cn-ticket-status.is-answered,
.cn-table-status.is-paid {
  color: #15803d;
  background: rgba(22, 163, 74, 0.12);
}

.cn-ticket-status.is-pending,
.cn-table-status.is-overdue {
  color: #dc2626;
  background: rgba(220, 38, 38, 0.12);
}

.cn-table-status.is-due {
  color: #b45309;
  background: rgba(245, 158, 11, 0.14);
}

.cn-table-wrap {
  overflow-x: auto;
}

.cn-invoice-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 620px;
}

.cn-invoice-table th,
.cn-invoice-table td {
  padding: 16px 12px;
  text-align: left;
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
}

.cn-invoice-table th {
  color: #667085;
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.cn-invoice-table tbody tr {
  transition: background var(--ease);
}

.cn-invoice-table tbody tr:hover {
  background: rgba(248, 250, 252, 0.9);
}

.cn-table-actions,
.cn-number-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.cn-action-btn,
.cn-modal-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: #ffffff;
  color: #0f172a;
  font-size: 0.9rem;
  font-weight: 700;
  text-decoration: none;
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease), background var(--ease);
}

.cn-action-btn:hover,
.cn-modal-submit:hover {
  transform: translateY(-2px);
  border-color: rgba(37, 99, 235, 0.22);
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.08);
}

.cn-action-btn--primary,
.cn-modal-submit {
  color: #ffffff;
  background: linear-gradient(135deg, #0f3dde 0%, #325dff 100%);
  border-color: transparent;
}

.cn-number-card__top {
  justify-content: flex-start;
}

.cn-numbers-card .cn-number-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cn-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 80;
  justify-content: center;
  align-items: center;
  padding: 20px;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(8px);
}

.cn-modal-box {
  width: min(100%, 420px);
  padding: 24px;
}

.cn-modal-box__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 20px;
}

.cn-modal-close {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: rgba(148, 163, 184, 0.12);
  color: #0f172a;
}

.cn-modal-box input {
  width: 100%;
  height: 54px;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px solid rgba(148, 163, 184, 0.24);
  background: #f8fafc;
  outline: none;
  transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
}

.cn-modal-box input:focus {
  background: #ffffff;
  border-color: rgba(37, 99, 235, 0.28);
  box-shadow: 0 0 0 5px rgba(37, 99, 235, 0.12);
}

.cn-payments {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 18px 0 22px;
}

.cn-payments span {
  margin: 0;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(241, 245, 249, 0.95);
  color: #334155;
  font-size: 0.82rem;
  font-weight: 700;
}

@media (max-width: 1100px) {
  .cn-company-meta,
  .cn-tabs-panel,
  .cn-dashboard-grid,
  .cn-numbers-card .cn-number-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cn-dashboard-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .cn-profile {
    padding-inline: 16px;
  }

  .cn-company-card,
  .cn-surface-card,
  .cn-tab-card,
  .cn-modal-box {
    border-radius: 20px;
  }

  .cn-company-card,
  .cn-surface-card {
    padding: 20px;
  }

  .cn-company-card__head,
  .cn-card-head,
  .cn-ticket-item {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }

  .cn-company-card__head,
  .cn-card-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .cn-company-meta,
  .cn-tabs-panel,
  .cn-numbers-card .cn-number-grid {
    grid-template-columns: 1fr;
  }

  .cn-ticket-item {
    display: grid;
  }

  .cn-action-btn,
  .cn-modal-submit {
    width: 100%;
  }
}

.cn-tariffs {
  background:#fff;
  padding:80px 20px;
  font-family: Font1;
}

.cn-container {
  max-width:1300px;
  margin:auto;
}

.cn-head h2 {
  font-size:34px;
  color:#090465;
}

.cn-layout {
  display:flex;
  gap:40px;
  margin-top:30px;
}

.cn-left {
  flex:3;
}

.cn-right {
  flex:1;
}

/* SEARCH */
.cn-search-box {
  background:#f8f9ff;
  padding:20px;
  border-radius:14px;
  margin-bottom:20px;
}

.cn-search-box input {
  width:100%;
  padding:14px;
  border-radius:10px;
  border:1px solid #ddd;
}

/* FILTERS */
.cn-filters {
  margin-top:10px;
}

.cn-filters button {
  padding:8px 14px;
  border:none;
  background:#eee;
  margin-right:5px;
  border-radius:8px;
  cursor:pointer;
}

.cn-filters button.active {
  background:#090465;
  color:#fff;
}

/* TABLE */
.cn-table-wrap {
  overflow:auto;
  max-height:600px;
}

table {
  width:100%;
  border-collapse:collapse;
}

th {
  background:#090465;
  color:white;
  padding:12px;
}

td {
  padding:10px;
  border-bottom:1px solid #eee;
}

tr:hover {
  background:#f2f4ff;
}

/* CALCULATOR */
.cn-calculator {
  position:sticky;
  top:100px;
  background:#090465;
  color:white;
  padding:25px;
  border-radius:16px;
}

.cn-calculator input {
  width:100%;
  padding:12px;
  margin-top:10px;
  border:none;
  border-radius:8px;
}

.cn-calculator button {
  width:100%;
  margin-top:10px;
  padding:12px;
  border:none;
  border-radius:8px;
  background:#a7a6fb;
  cursor:pointer;
}

.cn-result {
  margin-top:15px;
  font-size:20px;
  font-weight:bold;
}

/* MOBILE */
@media(max-width:900px){
  .cn-layout {
    flex-direction:column;
  }

  .cn-calculator {
    position:relative;
    top:0;
  }
}

.forum-ticket {
  background:#f5f6fb;
  padding:80px 20px;
  font-family: Font1;
}

.ft-container {
  max-width:900px;
  margin:auto;
}

/* MAIN TICKET */
.ft-ticket {
  background:white;
  padding:25px;
  border-radius:14px;
  margin-bottom:30px;
}

.ft-ticket h2 {
  color:#090465;
  margin-bottom:10px;
}

.ft-meta {
  font-size:13px;
  color:#777;
  display:flex;
  gap:15px;
  margin-bottom:15px;
}

.ft-text {
  font-size:15px;
}

/* ANSWERS */
.ft-answers h3 {
  margin-bottom:15px;
}

.ft-post {
  display:flex;
  gap:15px;
  background:white;
  padding:20px;
  border-radius:14px;
  margin-bottom:15px;
}

.ft-avatar {
  width:45px;
  height:45px;
  border-radius:50%;
  background:#090465;
  color:white;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:bold;
}

.ft-content {
  flex:1;
}

.ft-head {
  display:flex;
  justify-content:space-between;
  font-size:14px;
  margin-bottom:8px;
}

.ft-message {
  font-size:14px;
  line-height:1.6;
}

/* ROLE COLORS */
.admin {
  border-left:4px solid #090465;
}

.user {
  border-left:4px solid #a7a6fb;
}

/* REPLY */
.ft-reply {
  background:white;
  padding:20px;
  border-radius:14px;
  margin-top:20px;
}

.ft-reply textarea {
  width:100%;
  height:120px;
  padding:12px;
  border-radius:10px;
  border:1px solid #ddd;
}

.ft-reply button {
  margin-top:10px;
  padding:12px 20px;
  background:#090465;
  color:white;
  border:none;
  border-radius:10px;
}

/* MOBILE */
@media(max-width:600px){
  .ft-meta {
    flex-direction:column;
  }
}

.cn-packages[hidden] {
  display: none !important;
}

html.cn-pricing-scroll-root {
  scroll-snap-type: y proximity;
  scroll-padding-top: 156px;
}

.cn-pricing-experience {
  position: relative;
  padding: clamp(36px, 6vw, 72px) 0 120px;
  overflow: clip;
}

.cn-pricing-shell {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 24px;
}

.cn-pricing-intro {
  display: grid;
  gap: 16px;
  max-width: 980px;
}

.cn-pricing-intro h1 {
  margin: 0;
  max-width: 15ch;
  font-size: clamp(2.7rem, 6vw, 5.2rem);
  line-height: 0.92;
  letter-spacing: -0.07em;
  color: #0f1237;
}

.cn-pricing-intro p {
  margin: 0;
  max-width: 66ch;
  color: var(--muted);
  line-height: 1.72;
}

.cn-pricing-progress {
  position: sticky;
  top: 138px;
  z-index: 15;
  display: grid;
  gap: 14px;
  padding: 16px 18px;
  border-radius: 24px;
  border: 1px solid rgba(9, 4, 101, 0.08);
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(22px);
  box-shadow: 0 22px 48px rgba(9, 4, 101, 0.1);
}

.cn-pricing-progress__summary {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.cn-pricing-progress__summary span,
.cn-pricing-progress__summary small {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.cn-pricing-progress__summary strong {
  font-size: 1.1rem;
  color: var(--navy);
  letter-spacing: -0.03em;
}

.cn-pricing-progress__rail {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.cn-pricing-progress__rail a {
  display: grid;
  gap: 2px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(9, 4, 101, 0.06);
  background: rgba(248, 249, 255, 0.8);
  color: #3f4568;
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease), background var(--ease), color var(--ease);
}

.cn-pricing-progress__rail a span {
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.cn-pricing-progress__rail a strong {
  font-size: 0.92rem;
  letter-spacing: -0.03em;
}

.cn-pricing-progress__rail a:hover,
.cn-pricing-progress__rail a.is-active {
  transform: translateY(-2px);
  color: var(--navy);
  border-color: rgba(9, 4, 101, 0.14);
  background: linear-gradient(135deg, rgba(167, 166, 251, 0.22), rgba(255, 255, 255, 0.92));
  box-shadow: 0 14px 28px rgba(9, 4, 101, 0.1);
}

.cn-pricing-stack {
  display: grid;
  gap: clamp(22px, 3vw, 36px);
}

.cn-pricing-tier {
  --cn-tier-shift: 0px;
  --cn-tier-glow: rgba(167, 166, 251, 0.4);
  --cn-tier-line: rgba(9, 4, 101, 0.14);
  --cn-tier-base: rgba(255, 255, 255, 0.97);
  position: relative;
  min-height: calc(100svh - 156px);
  scroll-snap-align: start;
  scroll-snap-stop: always;
  opacity: 0;
  transform: translateY(36px);
  transition: opacity 0.7s var(--ease), transform 0.7s var(--ease);
}

.cn-pricing-tier.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.cn-pricing-tier--basic {
  --cn-tier-glow: rgba(9, 4, 101, 0.18);
  --cn-tier-line: rgba(9, 4, 101, 0.14);
}

.cn-pricing-tier--start {
  --cn-tier-glow: rgba(167, 166, 251, 0.48);
  --cn-tier-line: rgba(120, 118, 255, 0.24);
}

.cn-pricing-tier--plus {
  --cn-tier-glow: rgba(125, 124, 255, 0.38);
  --cn-tier-line: rgba(87, 85, 228, 0.18);
}

.cn-pricing-tier--comfort {
  --cn-tier-glow: rgba(9, 4, 101, 0.26);
  --cn-tier-line: rgba(9, 4, 101, 0.2);
}

.cn-pricing-panel {
  position: relative;
  min-height: 100%;
  overflow: hidden;
  border: 1px solid transparent;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 248, 255, 0.88)) padding-box,
    linear-gradient(135deg, rgba(9, 4, 101, 0.06), rgba(167, 166, 251, 0.48), rgba(9, 4, 101, 0.12)) border-box;
  box-shadow: 0 30px 70px rgba(12, 19, 59, 0.08);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}

.cn-pricing-panel::before,
.cn-pricing-panel::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.cn-pricing-panel::before {
  inset: -140px auto auto -100px;
  width: 260px;
  height: 260px;
  background: radial-gradient(circle, var(--cn-tier-glow), transparent 70%);
  transform: translate3d(0, calc(var(--cn-tier-shift) * 0.7), 0);
}

.cn-pricing-panel::after {
  inset: auto -80px -120px auto;
  width: 280px;
  height: 280px;
  background: radial-gradient(circle, rgba(9, 4, 101, 0.12), transparent 72%);
  transform: translate3d(0, calc(var(--cn-tier-shift) * -0.9), 0);
}

.cn-pricing-tier:hover .cn-pricing-panel {
  transform: translateY(-4px);
  box-shadow: 0 38px 88px rgba(12, 19, 59, 0.12);
}

.cn-pricing-tier.is-current .cn-pricing-panel {
  box-shadow:
    0 40px 100px rgba(9, 4, 101, 0.16),
    0 0 0 1px rgba(167, 166, 251, 0.22);
}

.cn-pricing-tier.is-current .cn-pricing-panel::before {
  animation: cnPricingGlowFloat 8s linear infinite;
}

.cn-pricing-panel__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(300px, 0.86fr) minmax(0, 1.14fr);
  gap: 24px;
  padding: clamp(22px, 4vw, 36px);
}

.cn-pricing-panel__lead,
.cn-pricing-panel__body {
  display: grid;
  align-content: start;
  gap: 20px;
}

.cn-pricing-panel__lead {
  padding: clamp(6px, 2vw, 12px);
}

.cn-pricing-topline {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.cn-pricing-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(9, 4, 101, 0.08);
  background: rgba(255, 255, 255, 0.78);
  color: var(--navy);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  box-shadow: 0 12px 28px rgba(9, 4, 101, 0.08);
}

.cn-pricing-chip--recommended {
  color: #ffffff;
  background: linear-gradient(135deg, #090465 0%, #3a34ca 100%);
  border-color: transparent;
}

.cn-pricing-heading {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}

.cn-pricing-heading__icon,
.cn-pricing-pricecard > .material-symbols-outlined,
.cn-pricing-metrics span,
.cn-pricing-featurelist .material-symbols-outlined,
.cn-pricing-link .material-symbols-outlined,
.cn-pricing-listhead > .material-symbols-outlined {
  display: grid;
  place-items: center;
  border-radius: 20px;
  font-variation-settings: "FILL" 1, "wght" 500, "GRAD" 0, "opsz" 24;
}

.cn-pricing-heading__icon {
  width: 72px;
  height: 72px;
  background: linear-gradient(145deg, rgba(167, 166, 251, 0.34), rgba(9, 4, 101, 0.08));
  color: var(--navy);
  box-shadow: 0 18px 34px rgba(9, 4, 101, 0.12);
}

.cn-pricing-kicker {
  display: block;
  margin-bottom: 6px;
  color: #6a6f8d;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.cn-pricing-heading h2 {
  margin: 0;
  font-size: clamp(2.4rem, 5vw, 4.2rem);
  line-height: 0.96;
  letter-spacing: -0.07em;
  color: #090c31;
}

.cn-pricing-highlight {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  margin: 0;
  padding: 12px 16px;
  border-radius: 18px;
  background: rgba(248, 249, 255, 0.92);
  color: #23284a;
  line-height: 1.55;
  border: 1px solid rgba(9, 4, 101, 0.07);
}

.cn-pricing-highlight .material-symbols-outlined {
  color: var(--navy);
  font-variation-settings: "FILL" 1, "wght" 500, "GRAD" 0, "opsz" 20;
}

.cn-pricing-pricecard {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 16px;
  padding: 18px;
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(244, 245, 255, 0.92)),
    rgba(255, 255, 255, 0.92);
  border: 1px solid var(--cn-tier-line);
  box-shadow: 0 20px 42px rgba(9, 4, 101, 0.08);
}

.cn-pricing-pricecard > .material-symbols-outlined {
  width: 68px;
  height: 68px;
  background: linear-gradient(145deg, rgba(9, 4, 101, 0.08), rgba(167, 166, 251, 0.32));
  color: var(--navy);
}

.cn-pricing-pricecard p {
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.65;
}

.cn-pricing-price {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  font-size: clamp(2.3rem, 5vw, 3.6rem);
  font-weight: 800;
  letter-spacing: -0.08em;
  color: #090c31;
}

.cn-pricing-price small {
  margin-bottom: 8px;
  font-size: 0.98rem;
  letter-spacing: -0.02em;
  color: #515879;
}

.cn-pricing-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.cn-pricing-metrics div {
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border-radius: 22px;
  border: 1px solid rgba(9, 4, 101, 0.08);
  background: rgba(255, 255, 255, 0.72);
}

.cn-pricing-metrics span {
  width: 42px;
  height: 42px;
  background: rgba(167, 166, 251, 0.22);
  color: var(--navy);
}

.cn-pricing-metrics strong {
  font-size: 1rem;
  color: #151936;
  letter-spacing: -0.03em;
}

.cn-pricing-metrics small {
  color: var(--muted);
  line-height: 1.55;
}

.cn-pricing-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.cn-pricing-cta {
  position: relative;
  overflow: hidden;
  min-width: 160px;
}

.cn-pricing-cta::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 -120%;
  width: 42%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.45), transparent);
  transition: transform 0.7s ease;
}

.cn-pricing-cta:hover::after {
  transform: translateX(290%);
}

.cn-pricing-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 50px;
  padding: 0 18px;
  border-radius: 16px;
  border: 1px solid rgba(9, 4, 101, 0.1);
  background: rgba(255, 255, 255, 0.78);
  color: var(--navy);
  font-weight: 700;
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease), background var(--ease);
}

.cn-pricing-link:hover {
  transform: translateY(-2px);
  background: #ffffff;
  border-color: rgba(9, 4, 101, 0.16);
  box-shadow: 0 16px 28px rgba(9, 4, 101, 0.08);
}

.cn-pricing-listhead {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 16px 18px;
  border-radius: 24px;
  border: 1px solid rgba(9, 4, 101, 0.08);
  background: rgba(255, 255, 255, 0.7);
}

.cn-pricing-listhead > .material-symbols-outlined {
  width: 56px;
  height: 56px;
  background: linear-gradient(145deg, rgba(167, 166, 251, 0.3), rgba(9, 4, 101, 0.08));
  color: var(--navy);
}

.cn-pricing-listhead strong {
  display: block;
  margin-bottom: 6px;
  color: #14183d;
  font-size: 1.02rem;
}

.cn-pricing-listhead p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.cn-pricing-featurelist {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.cn-pricing-featurelist li {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 14px 16px;
  border-radius: 20px;
  border: 1px solid rgba(9, 4, 101, 0.07);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 12px 26px rgba(9, 4, 101, 0.05);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}

.cn-pricing-featurelist li:hover {
  transform: translateY(-2px);
  border-color: rgba(9, 4, 101, 0.16);
  box-shadow: 0 18px 34px rgba(9, 4, 101, 0.08);
}

.cn-pricing-featurelist .material-symbols-outlined {
  width: 48px;
  height: 48px;
  background: rgba(167, 166, 251, 0.22);
  color: var(--navy);
}

.cn-pricing-featurelist span:last-child {
  color: #1b2040;
  line-height: 1.62;
}

.cn-pricing-orb {
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  filter: blur(24px);
  opacity: 0.8;
  animation: cnPricingOrbFloat 14s ease-in-out infinite;
}

.cn-pricing-orb--one {
  top: 10%;
  left: -90px;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(167, 166, 251, 0.38), transparent 70%);
}

.cn-pricing-orb--two {
  top: 28%;
  right: -110px;
  width: 280px;
  height: 280px;
  background: radial-gradient(circle, rgba(9, 4, 101, 0.16), transparent 70%);
  animation-delay: -4s;
}

.cn-pricing-orb--three {
  bottom: 8%;
  left: 14%;
  width: 180px;
  height: 180px;
  background: radial-gradient(circle, rgba(167, 166, 251, 0.26), transparent 72%);
  animation-delay: -8s;
}

@keyframes cnPricingGlowFloat {
  0% {
    transform: translate3d(0, calc(var(--cn-tier-shift) * 0.7), 0) scale(1);
  }
  50% {
    transform: translate3d(12px, calc(var(--cn-tier-shift) * 0.4), 0) scale(1.06);
  }
  100% {
    transform: translate3d(0, calc(var(--cn-tier-shift) * 0.7), 0) scale(1);
  }
}

@keyframes cnPricingOrbFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(0, -16px, 0);
  }
}

@media (max-width: 1100px) {
  .cn-pricing-panel__grid,
  .cn-pricing-featurelist {
    grid-template-columns: 1fr;
  }

  .cn-pricing-progress {
    top: 126px;
  }
}

@media (max-width: 760px) {
  html.cn-pricing-scroll-root {
    scroll-padding-top: 116px;
  }

  .cn-pricing-experience {
    padding: 28px 0 88px;
  }

  .cn-pricing-intro h1 {
    max-width: none;
  }

  .cn-pricing-progress {
    top: 96px;
    padding: 14px;
    border-radius: 20px;
  }

  .cn-pricing-progress__rail {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cn-pricing-tier {
    min-height: auto;
  }

  .cn-pricing-panel,
  .cn-pricing-listhead,
  .cn-pricing-featurelist li,
  .cn-pricing-pricecard,
  .cn-pricing-metrics div {
    border-radius: 22px;
  }

  .cn-pricing-panel__grid {
    padding: 18px;
    gap: 18px;
  }

  .cn-pricing-heading {
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 14px;
  }

  .cn-pricing-heading__icon,
  .cn-pricing-pricecard > .material-symbols-outlined {
    width: 58px;
    height: 58px;
    border-radius: 18px;
  }

  .cn-pricing-pricecard {
    grid-template-columns: 58px minmax(0, 1fr);
  }

  .cn-pricing-metrics,
  .cn-pricing-actions {
    grid-template-columns: 1fr;
  }

  .cn-pricing-actions {
    display: grid;
  }

  .cn-pricing-cta,
  .cn-pricing-link {
    width: 100%;
    justify-content: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  html.cn-pricing-scroll-root {
    scroll-snap-type: none;
  }

  .cn-pricing-tier,
  .cn-pricing-panel,
  .cn-pricing-progress__rail a,
  .cn-pricing-featurelist li,
  .cn-pricing-link,
  .cn-pricing-cta::after,
  .cn-pricing-orb,
  .cn-pricing-tier.is-current .cn-pricing-panel::before {
    animation: none !important;
    transition: none !important;
  }
}


.ct-cart{
  padding:80px 20px;
  background:#f4f6fb;
  font-family:'Font1',sans-serif;
}

.ct-wrapper{
  max-width:1400px;
  margin:auto;
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:50px;
}

/* TITLE */
.ct-title{
  font-size:38px;
  font-weight:700;
  margin-bottom:30px;
}

/* BOX */
.ct-box{
  background:#fff;
  border-radius:22px;
  padding:25px;
  margin-bottom:25px;
  box-shadow:0 20px 50px rgba(0,0,0,0.04);
}

.ct-box-head{
  display:flex;
  justify-content:space-between;
  margin-bottom:20px;
  font-weight:600;
}

.ct-items-count{
  color:#888;
  font-size:13px;
}

/* ITEM */
.ct-item{
  display:flex;
  align-items:center;
  gap:15px;
  padding:15px 0;
  border-bottom:1px solid #eee;
}

.ct-item img{
  width:80px;
  border-radius:14px;
}

.ct-info{
  flex:1;
}

.ct-name{
  font-weight:600;
}

.ct-sub{
  font-size:13px;
  color:#888;
}

.ct-qty{
  color:#555;
}

.ct-price{
  font-weight:700;
}

/* FORM */
.ct-form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:15px;
}

.ct-field{
  display:flex;
  align-items:center;
  background:#f9fafc;
  border-radius:16px;
  padding:12px;
  border:1px solid #eee;
}

.ct-field span{
  margin-right:10px;
  color:#090465;
}

.ct-field input{
  border:none;
  width:100%;
  background:none;
  outline:none;
}

.ct-field.full{
  grid-column:span 2;
}

/* RIGHT */
.ct-summary{
  background:#fff;
  border-radius:24px;
  padding:25px;
  position:sticky;
  top:30px;
  box-shadow:0 25px 60px rgba(0,0,0,0.06);
}

/* BLOCK */
.ct-block{
  margin-bottom:25px;
}

.ct-block-title{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:600;
  margin-bottom:12px;
}

/* ADDRESS */
.ct-address{
  width:100%;
  height:45px;
  border-radius:12px;
  border:1px solid #ddd;
  padding:0 12px;
}

/* PAYMENT */
.ct-payments{
  display:flex;
  gap:10px;
}

.ct-pay{
  flex:1;
  padding:12px;
  text-align:center;
  border-radius:14px;
  border:1px solid #ddd;
  cursor:pointer;
  transition:.3s;
}

.ct-pay.active,
.ct-pay:hover{
  background:#090465;
  color:#fff;
}

/* ROW */
.ct-row{
  display:flex;
  justify-content:space-between;
  margin-bottom:10px;
}

.ct-total{
  display:flex;
  justify-content:space-between;
  font-size:20px;
  font-weight:700;
  margin-top:10px;
}

/* BUTTON */
.ct-pay-btn{
  width:100%;
  height:55px;
  border:none;
  border-radius:18px;
  background:#090465;
  color:#fff;
  font-size:16px;
  font-weight:600;
  cursor:pointer;
  transition:.3s;
}

.ct-pay-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 15px 30px rgba(9,4,101,0.2);
}

/* MOBILE */
@media(max-width:992px){
  .ct-wrapper{
    grid-template-columns:1fr;
  }
}

.logo-full {
  width: 250px;
}

.voip-product {
  width: min(calc(100% - 32px), var(--container));
  margin: 0 auto;
  padding: clamp(28px, 4vw, 48px) 0 88px;
}

.vp-container {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(0, 0.98fr) minmax(280px, 0.76fr);
  gap: clamp(20px, 2.5vw, 28px);
  align-items: start;
  padding: clamp(18px, 3vw, 28px);
  border: 1px solid rgba(9, 4, 101, 0.08);
  border-radius: 30px;
  background:
    radial-gradient(circle at top left, rgba(167, 166, 251, 0.16), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 249, 255, 0.88));
  box-shadow: 0 28px 70px rgba(9, 4, 101, 0.08);
  overflow: hidden;
}

.vp-container::after {
  content: "";
  position: absolute;
  inset: auto -120px -140px auto;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(9, 4, 101, 0.08), transparent 68%);
  pointer-events: none;
}

.vp-left,
.vp-middle,
.vp-right,
.vp-description,
.vp-related {
  position: relative;
  z-index: 1;
}

.vp-gallery,
.vp-middle,
.vp-right,
.vp-description,
.vp-card {
  border: 1px solid rgba(9, 4, 101, 0.08);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 18px 44px rgba(9, 4, 101, 0.06);
  backdrop-filter: blur(16px);
}

.vp-gallery {
  padding: 16px;
}

.vp-gallery-stage {
  position: relative;
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) 56px;
  gap: 12px;
  align-items: center;
}

.vp-gallery-frame {
  position: relative;
  min-height: clamp(320px, 38vw, 500px);
  padding: 20px;
  border-radius: 22px;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(167, 166, 251, 0.22), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #f3f5ff 100%);
  border: 1px solid rgba(9, 4, 101, 0.06);
}

.vp-gallery-badge {
  position: absolute;
  top: 16px;
  left: 16px;
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(9, 4, 101, 0.08);
  color: var(--navy);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 0 12px 24px rgba(9, 4, 101, 0.08);
}

.vp-main-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: opacity 0.28s ease, transform 0.28s ease;
}

.vp-main-image.is-swapping {
  opacity: 0;
  transform: scale(0.98);
}

.vp-gallery-arrow {
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border-radius: 18px;
  border: 1px solid rgba(9, 4, 101, 0.08);
  background: rgba(255, 255, 255, 0.9);
  color: var(--navy);
  box-shadow: 0 14px 32px rgba(9, 4, 101, 0.08);
  transition: transform var(--ease), box-shadow var(--ease), background var(--ease);
}

.vp-gallery-arrow:hover {
  transform: translateY(-2px);
  background: #ffffff;
  box-shadow: 0 18px 36px rgba(9, 4, 101, 0.12);
}

.vp-gallery-arrow svg,
.vp-spec-icon svg,
.vp-btn svg {
  width: 20px;
  height: 20px;
}

.vp-thumbs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.vp-thumb {
  padding: 10px;
  border-radius: 18px;
  border: 1px solid rgba(9, 4, 101, 0.08);
  background: rgba(248, 249, 255, 0.85);
  transition: transform var(--ease), border-color var(--ease), box-shadow var(--ease), background var(--ease);
}

.vp-thumb:hover,
.vp-thumb.is-active {
  transform: translateY(-2px);
  border-color: rgba(9, 4, 101, 0.18);
  background: #ffffff;
  box-shadow: 0 16px 28px rgba(9, 4, 101, 0.1);
}

.vp-thumb img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.vp-middle {
  padding: clamp(22px, 3vw, 30px);
}

.vp-tag {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(167, 166, 251, 0.14);
  color: var(--navy);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.vp-middle h1,
.vp-description h2,
.vp-related h2 {
  margin: 16px 0 10px;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  line-height: 0.96;
  letter-spacing: -0.06em;
  color: #0f1237;
}

.vp-sub {
  margin: 0 0 24px;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.7;
}

.vp-specs {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.vp-specs li {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid rgba(9, 4, 101, 0.07);
  background: rgba(249, 250, 255, 0.9);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}

.vp-specs li:hover {
  transform: translateY(-2px);
  border-color: rgba(9, 4, 101, 0.14);
  box-shadow: 0 18px 30px rgba(9, 4, 101, 0.08);
}

.vp-spec-icon {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(167, 166, 251, 0.28), rgba(9, 4, 101, 0.08));
  color: var(--navy);
}

.vp-specs strong {
  display: block;
  margin-bottom: 6px;
  font-size: 1rem;
  color: #161a3a;
  letter-spacing: -0.03em;
}

.vp-specs span:last-child {
  color: var(--muted);
  line-height: 1.6;
}

.vp-right {
  position: sticky;
  top: 138px;
  display: grid;
  gap: 18px;
  padding: 24px;
}

.vp-buy-head {
  display: grid;
  gap: 6px;
}

.vp-buy-label,
.vp-qty-label {
  color: #6d7291;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.vp-buy-note {
  color: var(--muted);
  line-height: 1.55;
}

.vp-price {
  margin: 0;
  font-size: clamp(2.4rem, 4vw, 3.4rem);
  font-weight: 800;
  letter-spacing: -0.08em;
  color: var(--navy);
}

.vp-qty {
  display: grid;
  gap: 10px;
}

.vp-qty-control {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 64px;
  padding: 8px;
  border-radius: 18px;
  border: 1px solid rgba(9, 4, 101, 0.08);
  background: rgba(248, 249, 255, 0.9);
}

.vp-qty-control button {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: #ffffff;
  color: var(--navy);
  border: 1px solid rgba(9, 4, 101, 0.08);
  box-shadow: 0 10px 22px rgba(9, 4, 101, 0.08);
  transition: transform var(--ease), box-shadow var(--ease), background var(--ease);
}

.vp-qty-control button:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 24px rgba(9, 4, 101, 0.12);
}

#vpQty {
  min-width: 36px;
  text-align: center;
  font-size: 1.2rem;
  font-weight: 800;
  color: #151936;
}

.vp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  min-height: 56px;
  padding: 0 20px;
  border-radius: 18px;
  font-weight: 800;
  letter-spacing: -0.02em;
  text-decoration: none;
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease), background var(--ease), color var(--ease);
}

.vp-btn:hover {
  transform: translateY(-2px);
}

.vp-add {
  color: #ffffff;
  background: linear-gradient(135deg, #090465 0%, #2c27b5 100%);
  box-shadow: 0 20px 38px rgba(9, 4, 101, 0.22);
}

.vp-add:hover {
  box-shadow: 0 24px 42px rgba(9, 4, 101, 0.28);
}

.vp-call {
  color: var(--navy);
  background: rgba(248, 249, 255, 0.92);
  border: 1px solid rgba(9, 4, 101, 0.1);
}

.vp-call:hover {
  background: #ffffff;
  border-color: rgba(9, 4, 101, 0.16);
  box-shadow: 0 16px 28px rgba(9, 4, 101, 0.08);
}

.vp-description,
.vp-related {
  margin-top: 24px;
  padding: clamp(22px, 3vw, 30px);
}

.vp-description h2,
.vp-related h2 {
  margin-top: 0;
  font-size: clamp(1.6rem, 2.8vw, 2.2rem);
}

.vp-description-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(240px, 0.75fr);
  gap: 24px;
  align-items: start;
}

.vp-description p {
  margin: 0;
  color: var(--muted);
  line-height: 1.8;
}

.vp-description-list {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.vp-description-list li {
  position: relative;
  padding-left: 18px;
  color: #1c2141;
  line-height: 1.65;
}

.vp-description-list li::before {
  content: "";
  position: absolute;
  top: 11px;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #090465, #8b89ff);
}

.vp-related-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.vp-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}

.vp-card:hover {
  transform: translateY(-4px);
  border-color: rgba(9, 4, 101, 0.14);
  box-shadow: 0 24px 42px rgba(9, 4, 101, 0.1);
}

.vp-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  padding: 12px;
  border-radius: 18px;
  background: linear-gradient(180deg, #f8f9ff 0%, #eef2ff 100%);
}

.vp-card h4 {
  margin: 0;
  font-size: 1.02rem;
  letter-spacing: -0.03em;
  color: #171b3d;
}

.vp-card span {
  color: var(--navy);
  font-weight: 800;
  letter-spacing: -0.03em;
}

@media (max-width: 1180px) {
  .vp-container {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .vp-right,
  .vp-description-grid {
    grid-column: 1 / -1;
  }

  .vp-right {
    position: static;
  }

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

@media (max-width: 860px) {
  .logo-full {
    width: 210px;
  }

  .voip-product {
    padding-bottom: 72px;
  }

  .vp-container {
    grid-template-columns: 1fr;
    padding: 16px;
    border-radius: 24px;
  }

  .vp-gallery-stage {
    grid-template-columns: 44px minmax(0, 1fr) 44px;
    gap: 8px;
  }

  .vp-gallery-arrow {
    width: 44px;
    height: 44px;
    border-radius: 14px;
  }

  .vp-middle,
  .vp-right,
  .vp-description,
  .vp-related,
  .vp-gallery {
    border-radius: 22px;
  }

  .vp-right {
    position: sticky;
    bottom: 12px;
    z-index: 12;
  }

  .vp-description-grid,
  .vp-related-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .logo-full {
    width: 180px;
  }

  .vp-middle,
  .vp-right,
  .vp-description,
  .vp-related {
    padding: 18px;
  }

  .vp-middle h1 {
    font-size: 2rem;
  }

  .vp-specs li {
    grid-template-columns: 44px minmax(0, 1fr);
    padding: 12px;
  }

  .vp-spec-icon {
    width: 44px;
    height: 44px;
    border-radius: 14px;
  }

  .vp-thumbs {
    gap: 8px;
  }

  .vp-thumb {
    padding: 8px;
    border-radius: 14px;
  }

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