:root {
  --color-primary: #00bfff;
  --color-secondary: #ADF802;
  --color-accent: #ADF802;
  --color-base-100: #dce9f4;
  --color-base-200: #c9d9e7;
  --color-base-content: #1b2430;
}

html { scroll-behavior: smooth; }
body {
  background:
    radial-gradient(circle at top left, rgba(0, 191, 255, 0.18), transparent 28%),
    radial-gradient(circle at top right, rgba(173, 248, 2, 0.14), transparent 22%),
    linear-gradient(180deg, #dbe8f3 0%, #e8f1f8 36%, #d9e6f1 100%);
}

.navbar {
  min-height: 4.5rem;
}

.navbar-modern {
  box-shadow: 0 18px 50px rgba(5, 18, 34, 0.10);
  transition: padding 180ms ease, background-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.navbar-modern.navbar-compact {
  background: rgba(220, 233, 244, 0.92);
  box-shadow: 0 14px 36px rgba(5, 18, 34, 0.10);
}
.navbar-modern.navbar-compact .brand-pill {
  transform: scale(0.96);
}

.navbar-start,
.navbar-end {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
}

.brand-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  padding: 0.55rem 0.8rem;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(230, 241, 248, 0.82));
  border: 1px solid rgba(27, 36, 48, 0.08);
}
.brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  color: #fff;
  font-size: 0.95rem;
  font-weight: 900;
}
.brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border-radius: 1rem;
  border: 1px solid transparent;
  padding: 0.7rem 1rem;
  font-weight: 700;
  transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn-sm { padding: 0.55rem 0.85rem; font-size: 0.875rem; }
.btn-ghost { background: transparent; }
.btn-outline { border-color: rgba(27, 36, 48, 0.14); background: rgba(255,255,255,.35); color: var(--color-base-content); }
.btn-primary { background: var(--color-primary); color: #fff; }

.menu { list-style: none; margin: 0; padding: 0; }
.menu li a {
  display: inline-flex;
  border-radius: 0.9rem;
  padding: 0.7rem 1rem;
  font-weight: 600;
  color: rgba(27, 36, 48, 0.78);
  position: relative;
  overflow: hidden;
}
.menu li a:hover,
.menu li a.active {
  background: linear-gradient(180deg, rgba(0, 191, 255, 0.16), rgba(173, 248, 2, 0.12));
  color: var(--color-primary);
}
.menu li a.active::after {
  content: '';
  position: absolute;
  left: 14%;
  right: 14%;
  bottom: 0.28rem;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-secondary));
}
.menu-horizontal { display: flex; align-items: center; gap: 0.15rem; }

.nav-cta {
  background: linear-gradient(135deg, var(--color-primary), #007bb8);
  box-shadow: 0 12px 30px rgba(0, 191, 255, 0.25);
}
.nav-cta:hover {
  background: linear-gradient(135deg, #0095e1, #006fa3);
}

.link { color: var(--color-primary); text-decoration: none; }
.link-hover:hover { text-decoration: underline; }

.footer {
  border-top: 1px solid rgba(27, 36, 48, 0.10);
}

.hero-motion canvas {
  will-change: transform;
  transition: transform 180ms ease-out;
}

.bg-base-100 { background-color: var(--color-base-100); }
.bg-base-200 { background-color: var(--color-base-200); }
.bg-white { background-color: var(--color-base-100) !important; }
.text-base-content { color: var(--color-base-content); }
.text-primary { color: var(--color-primary); }
.text-secondary { color: var(--color-secondary); }
.text-accent { color: var(--color-accent); }
.border-base-200 { border-color: rgba(27, 36, 48, 0.08); }

@media (max-width: 1023px) {
  .navbar {
    flex-wrap: wrap;
  }
  .navbar-start {
    flex: 1 1 auto;
  }
  .navbar-end {
    margin-left: auto;
  }
  .nav-links {
    position: absolute;
    right: 1rem;
    top: calc(100% + 0.75rem);
    z-index: 50;
    flex-direction: column;
    align-items: stretch;
    gap: 0.25rem;
    width: min(22rem, calc(100vw - 2rem));
    padding: 0.95rem;
    border-radius: 1.4rem;
    border: 1px solid rgba(27, 36, 48, 0.08);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(233, 242, 249, 0.98));
    box-shadow: 0 22px 60px rgba(5, 18, 34, 0.20);
  }
  .nav-links.hidden { display: none; }
  .brand-text { max-width: 10rem; }
}

