/*-- -------------------------- -->
<---      Call To Action      -->
<--- -------------------------- -*/
@keyframes bulbGlow { 0% { opacity: 1; } 19% { opacity: 1; } 20% { opacity: 0.3; } 21% { opacity: 1; } 59% { opacity: 1; } 60% { opacity: 0.3; } 61% { opacity: 1; } 62% { opacity: 0.3; } 63% { opacity: 1; } 100% { opacity: 1; } } 
/* Desktop and up: 1024px */
@media (min-width: 1024px) { 
    #cta-1693 .cs-lights-wrapper, #cta-1693 .cs-lights { width: 57.75em; } 
    #cta-1693 .light1 { left: -1.25em; animation-delay: 3s; } 
    #cta-1693 .light2 { left: 9.9375em; animation-delay: 5s; } 
    #cta-1693 .light3 { left: 21.1875em; animation-delay: 0.1s; } 
    #cta-1693 .light4 { left: 32.9375em; animation-delay: 4s; display: block; } 
    #cta-1693 .light5 { left: 44.125em; animation-delay: 2.5s; display: block; } 
    #cta-1693 .cs-bulb1 { left: 4.875em; animation-delay: 3s; } 
    #cta-1693 .cs-bulb2 { left: 16.875em; animation-delay: 5s; } 
    #cta-1693 .cs-bulb3 { left: 28em; animation-delay: 0.1s; } 
    #cta-1693 .cs-bulb4 { display: block; left: 39.6875em; animation-delay: 4s; } 
    #cta-1693 .cs-bulb5 { display: block; left: 50.9375em; animation-delay: 2.5s; } 
} 
body.dark #cta-1693 .cs-container:before { box-sizing: border-box; background: radial-gradient(ellipse at center, #143f6d 0%, #01060a 78%); } 
body.dark #cta-1693 .cs-container:after { border-color: #01060a; } 
body.dark #cta-1693 .cs-flare { animation: bilboardGlow 15.2s forwards infinite; animation-delay: 0.7s; } 
body.dark #cta-1693 .cs-bulb { animation: bulbGlow 15.2s forwards infinite; animation-delay: 0.7s; } 
body.dark #cta-1693 .light1 { animation-delay: 3s; } 
body.dark #cta-1693 .light2 { animation-delay: 5s; } 
body.dark #cta-1693 .light3 { animation-delay: 0.1s; } 
body.dark #cta-1693 .light4 { animation-delay: 4s; } 
body.dark #cta-1693 .light5 { animation-delay: 2.5s; } 
body.dark #cta-1693 .cs-bulb1 { animation-delay: 3s; } 
body.dark #cta-1693 .cs-bulb2 { animation-delay: 5s; } 
body.dark #cta-1693 .cs-bulb3 { animation-delay: 0.1s; } 
body.dark #cta-1693 .cs-bulb4 { animation-delay: 4s; } 
body.dark #cta-1693 .cs-bulb5 { animation-delay: 2.5s; } 
body.dark #cta-1693 .cs-lights-wrapper { transform: translateX(-50%) translateY(0); animation: wrapperZ 0.35s forwards; }

/*-- -------------------------- -->
<---          Glossary          -->
<--- -------------------------- -*/
#glossary-hero { padding-top: 8rem; padding-bottom: 0; text-align: center; background-color: var(--background); position: relative; z-index: 1;}
.dark #glossary-hero { background: linear-gradient(145deg, #00031F 0%, #0C2B33 96%); }
#glossary-content-section { background-color: var(--secondary); padding-top: 0; overflow: visible; overflow-x: clip; }
#glossary-content-section .container { padding-top: 4rem; }
@media (min-width: 1024px) { #glossary-content-section .container { padding-top: 6rem; } }
.cs-footer-swoosh-container { color: var(--secondary); background-color: var(--background); position: relative; z-index: 1; line-height: 0; }
.cs-footer-swoosh { width: 100%; height: auto; display: block; }
.search-bar-wrapper { position: relative; max-width: 774px; margin: 2rem auto 0; }
.search-bar-wrapper svg { position: absolute; left: 1.5rem; top: 50%; transform: translateY(-50%); color: var(--muted-foreground); width: 20px; height: 20px; }
#search-input { height: 68px; width: 100%; border-radius: 1rem; padding: 0 1.5rem 0 4.5rem; background-color: var(--card); border: 1px solid var(--border); color: var(--foreground); font-size: 1.125rem; line-height: 1.75rem; outline: none; transition: border-color 0.3s, box-shadow 0.3s; }
#search-input::placeholder { color: var(--muted-foreground); }
#search-input:focus { border-color: var(--primary); box-shadow: 0 0 0 2px hsla(var(--primary-hsl), 0.5); }
#glossary-grid { display: grid; grid-template-columns: 1fr; gap: 4rem; }
@media(min-width: 1024px) { #glossary-grid { grid-template-columns: minmax(0, 1fr) auto; } }
#glossary-list { list-style: none; display: grid; gap: 5rem; }
.glossary-section { scroll-margin-top: 7rem; }
@media(min-width: 768px) { .glossary-section { display: grid; grid-template-columns: 150px 1fr; gap: 2rem; } }
.glossary-section h2 { font-size: clamp(2rem, 4vw, 2.25rem); font-weight: 600; line-height: 1.2; letter-spacing: 0.08em; text-transform: uppercase; position: relative; }
.glossary-section h2::after { content: ''; display: block; width: 3.5rem; height: 3px; margin-top: 0.35rem; margin-bottom: 0.5rem; border-radius: 9999px; background: linear-gradient(90deg, hsl(var(--accent-hsl)), hsl(var(--primary-hsl))); }
.glossary-items { list-style: none; display: grid; gap: 3rem; }
.glossary-item a { text-decoration: none; display: grid; gap: 0.75rem; }
.glossary-item h3 { font-size: 1.5rem; font-weight: 700; color: var(--foreground); transition: color 0.3s; }
.glossary-item a:hover h3 { color: var(--primary); text-decoration: underline; }
.glossary-item p { color: var(--muted-foreground); line-height: 1.7; }
#alphabet-nav-mobile { display: flex; overflow-x: auto; padding: 0.5rem 0; margin: 0 -1rem 2.5rem; border-bottom: 1px solid var(--border); position: sticky; top: 56px; z-index: 40; background: var(--secondary); }
#alphabet-nav-mobile li { list-style: none; }
#alphabet-nav-mobile .alphabet-nav-button { background: none; border: none; font-size: 0.875rem; color: var(--muted-foreground); padding: 0.25rem 0.5rem; cursor: pointer; white-space: nowrap; transition: color 0.3s; }
#alphabet-nav-mobile .alphabet-nav-button.active { color: var(--primary); font-weight: 700; }
@media(min-width: 1024px) { #alphabet-nav-mobile { display: none; } }
#alphabet-nav-desktop { display: none; }
@media(min-width: 1024px) { 
    /* place the alphabet nav in the second column, keep it narrow */
    #alphabet-nav-desktop { display: block; position: sticky; top: 7rem; justify-self: end; align-self: start; padding-left: 2rem; list-style: none; } 
    #alphabet-nav-desktop .alphabet-nav-button { background: none; border: none; display: grid; height: 2rem; width: 1.5rem; align-items: center; justify-items: start; font-size: 0.875rem; color: var(--muted-foreground); border-right: 1px solid var(--border); transition: color 0.3s; cursor: pointer; } 
    #alphabet-nav-desktop .alphabet-nav-button.active { color: var(--primary); font-weight: 700; } 
    #alphabet-indicator { position: absolute; width: 2px; height: 2rem; background-color: var(--primary); border-radius: 9999px; right: -1px; transition: top 0.3s var(--ease-out-cubic); } 
}