.nav-links > li.dropdown:last-child .dropdown-content {
    left: auto;
    right: 0;
}
/* Home hero and explore sections */
.hero {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20dvh;
    background: none;
    padding: 3rem 0 2rem 0;
}

.hero-card {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 2.5rem;
    background: rgba(255,255,255,0.18);
    box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.18);
    border-radius: 2.5rem;
    padding: 2.5rem 3rem;
    max-width: 800px;
    margin: 0 1rem;
    border: 1.5px solid rgba(182,224,254,0.35);
    backdrop-filter: blur(18px) saturate(180%);
    -webkit-backdrop-filter: blur(18px) saturate(180%);
    position: relative;
    overflow: hidden;
}

.hero-image {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
}
.hero-info {
    flex: 1 1 0;
}
.hero-card h1 {
    font-size: 2.5rem;
    color: white;
    margin-bottom: 1rem;
    letter-spacing: 0.03em;
    text-shadow: 0 2px 12px #b6e0fe;
}
.hero-description {
    font-size: 1.2rem;
    color: white;
    margin-bottom: 0;
}

.home-explore {
    max-width: 1100px;
    margin: 3rem auto 2rem auto;
    padding: 2rem 1rem;
    background: rgba(255,255,255,0.13);
    border-radius: 1.5rem;
    box-shadow: 0 4px 18px 0 rgba(0,40,80,0.09);
    border: 1.5px solid rgba(182,224,254,0.25);
    backdrop-filter: blur(10px) saturate(160%);
    -webkit-backdrop-filter: blur(10px) saturate(160%);
}
.home-explore h2 {
    color: white;
    font-size: 2rem;
    margin-bottom: 2rem;
    text-align: center;
}
.explore-cards {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    justify-content: center;
}
.explore-card {
    background: rgba(255,255,255,0.22);
    border-radius: 1.2rem;
    box-shadow: 0 4px 18px 0 rgba(31, 38, 135, 0.10);
    border: 1.5px solid rgba(182,224,254,0.18);
    padding: 1.5rem 1.2rem;
    min-width: 220px;
    max-width: 260px;
    flex: 1 1 220px;
    text-align: center;
    transition: box-shadow 0.2s, transform 0.2s;
    cursor: pointer;
}
.explore-card:hover {
    box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.18);
    transform: translateY(-4px) scale(1.03);
}
.explore-card h3 {
    color: white;
    margin-bottom: 0.7rem;
    font-size: 1.25rem;
}
.explore-card p {
    color: white;
    font-size: 1rem;
    margin-bottom: 1.2rem;
}

.learn-more-button,
.explore-card a {
    display: inline-block;
    margin-top: 0.5rem;
    padding: 0.4rem 1.1rem;
    background: linear-gradient(90deg, #b6e0fe 0%, #e3f0ff 100%);
    color: #1a5fa2;
    border-radius: 0.7rem;
    text-decoration: none;
    font-weight: 500;
    transition: background 0.2s, color 0.2s;
}

.learn-more-button:hover,
.explore-card a:hover {
    background: #1a5fa2;
    color: #fff;
}

@media (max-width: 900px) {
    .hero-card {
        flex-direction: column;
        padding: 2rem 1rem;
        gap: 1.5rem;
    }
    .explore-cards {
        flex-direction: column;
        gap: 1.5rem;
    }
}

.background {
    position: fixed;
    height: 100dvh;
    width: 100dvw;
    background:
        radial-gradient(900px 700px at 15% 20%, hsla(210.1, 100%, 46.5%, 0.19), transparent 65%), 
        radial-gradient(900px 700px at 85% 30%, hsla(220.4, 28.3%, 36.1%, 0.5), transparent 70%), 
        radial-gradient(700px 600px at 85% 85%, hsla(28.3, 88.1%, 46.3%, 0.17), transparent 72%), 
        linear-gradient(180deg, hsl(220, 18%, 18%) 0%, hsl(220, 20%, 12%) 100%);
    z-index: -1;
}

body {
    margin: 0;
    font-family: sans-serif;
    color: #fff;
    min-height: 100vh;
    padding-bottom: 50px;

}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.05; /* 0.03–0.07 */
  background-image: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'>\
<filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/></filter>\
<rect width='120' height='120' filter='url(%23n)' opacity='1'/>\
</svg>");
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(1200px 900px at 50% -10%, rgba(255,255,255,0.06), transparent 60%),
    radial-gradient(1400px 1000px at 50% 110%, rgba(0,0,0,0.25), transparent 55%);
  mix-blend-mode: soft-light;
  opacity: 0.9;
}


header {
    background: rgba(255, 255, 255, 0.54);
    box-shadow: 0 2px 12px 0 rgba(0,40,80,0.08);
    backdrop-filter: blur(6px);
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 100;
    max-height: 70px;
}

main {
    margin-top: 70px;
    padding: 1rem;
}

footer {
    background: rgba(255, 255, 255, 0.08);
    font-size: 0.9rem;
    color: white;
    box-shadow: 0 -2px 12px 0 rgba(0,40,80,0.08);
    backdrop-filter: blur(6px);
    position: fixed;
    width: 100%;
    bottom: 0;
    left: 0;
    z-index: 100;
    padding-inline: 1em;
    display: flex;
}

.navbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.7rem 2.5rem;
}

.logo {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    color: #1a5fa2;
    text-shadow: 0 2px 8px #b6e0fe;
}

.nav-links {
    list-style: none;
    display: flex;
    gap: 2rem;
    margin: 0;
    padding: 0;
}

.nav-links li {
    position: relative;
}

.nav-links a {
    text-decoration: none;
    color: #1a222c;
    font-weight: 500;
    font-size: 1.1rem;
    padding: 0.5rem 1rem;
    border-radius: 8px;
    transition: background 0.2s, color 0.2s;
}

.nav-links a:hover, .nav-links .dropbtn:hover {
    background: linear-gradient(90deg, #b6e0fe 0%, #e3f0ff 100%);
    color: #1a5fa2;
}

.dropdown-content {
    display: none;
    position: absolute;
    background: rgba(255,255,255,0.97);
    min-width: 180px;
    box-shadow: 0 8px 24px 0 rgba(0,40,80,0.12);
    border-radius: 10px;
    z-index: 1;
    top: 110%;
    left: 0;
    padding: 0.5rem 0;
}

.dropdown-content a {
    display: block;
    padding: 0.7rem 1.2rem;
    color: white;
    border-radius: 0;
    font-size: 1rem;
    margin: 8px;
}

.dropdown-content a:hover {
    background: linear-gradient(90deg, #b6e0fe9a 0%, #e3f0ff8a 100%);
    color: #0a5ab1;
    border-radius: 12px;
}

.dropdown:hover .dropdown-content {
    display: block;
}

.product-page, .labs-page {
    max-width: 700px;
    margin: 3rem auto;
    background: rgba(255,255,255,0.93);
    border-radius: 1.5rem;
    box-shadow: 0 4px 18px 0 rgba(0,40,80,0.09);
    padding: 2.5rem 2rem;
    border: 1.5px solid #b6e0fe;
    color: white;
}

.product-page h1, .labs-page h1 {
    color: white;
    font-size: 35pt;
    margin-bottom: 1rem;
}

@media (max-width: 700px) {
    .navbar {
        flex-direction: column;
        align-items: flex-start;
        padding: 1rem;
    }

    .product-page, .labs-page {
        padding: 1.2rem 0.5rem;
    }
}

a.as-p {
  all: unset;    
  display: block;      
  font: inherit;     
  color: inherit;     
  line-height: inherit;
  margin: 1em 0;   
  cursor: pointer;      
}

@font-face {
    font-family: 'Montserrat';
    src: url('/static/Montserrat-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

.glass {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0.08));
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow:
    0 12px 40px rgba(0,0,0,0.35),
    inset 0 1px 0 rgba(255,255,255,0.18);
}

.feature-card {
    border-radius: 1.2rem; 
    padding: 1.5rem 1.2rem; 
    min-width: 220px;
    max-width: 260px; 
    flex: 1 1 220px;
    text-align: center;
    color: white !important;
}