/* ===== FONTS ===== */
@font-face {
    font-family: 'Neusa Next Pro Regular';
    src: url('fonts/NeusaNextPro-Regular.otf') format('opentype');
    font-display: swap;
}

@font-face {
    font-family: 'Neusa Next Pro Medium';
    src: url('fonts/NeusaNextPro-Medium.otf') format('opentype');
    font-display: swap;
}

@font-face {
    font-family: 'Neusa Next Pro Bold';
    src: url('fonts/NeusaNextPro-Bold.otf') format('opentype');
    font-display: swap;
}

/* ===== CSS VARIABLES ===== */
:root {
    --color-light-gray: rgb(248, 247, 247);
    --color-black: rgb(0, 0, 0);
    --color-lightgreen: rgb(148, 183, 188);

    --font-regular: 'Neusa Next Pro Regular', serif;
    --font-medium: 'Neusa Next Pro Medium', serif;
    --font-bold: 'Neusa Next Pro Bold', serif;
}

/* ===== RESET & BASE ===== */
html, body {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

* {
    box-sizing: border-box;
    -webkit-font-smoothing: inherit;
}

h1, h2, h3, h4, h5, h6, p, figure {
    margin: 0;
}

body {
    font-family: var(--font-regular);
    font-size: 12px;
    color: var(--color-black);
    background-color: var(--color-light-gray);
}

a {
    color: inherit;
    text-decoration: none;
}

/* ===== PAGE LAYOUT ===== */
.page {
    align-content: center;
    align-items: center;
    background-color: var(--color-light-gray);
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0;
    height: min-content;
    justify-content: flex-start;
    overflow: hidden;
    padding: 0;
    position: relative;
    width: 100%;
    margin: 0 auto;
}

/* ===== CONTENT SECTIONS WRAPPER ===== */
.content-sections {
    align-content: center;
    align-items: center;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0;
    height: min-content;
    justify-content: flex-start;
    overflow: visible;
    padding: 0;
    position: relative;
    width: 100%;
}

.content-sections > * {
    margin: 80px 0;
}

.content-sections > :first-child {
    margin-top: 0;
}

.content-sections > :last-child {
    margin-bottom: 0;
}

/* ===== HERO SECTION ===== */
.section-hero {
    align-content: center;
    align-items: center;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 80px;
    height: 100vh;
    justify-content: center;
    overflow: visible;
    padding: 0;
    position: relative;
    width: 100%;
}

.hero-content {
    align-content: flex-start;
    align-items: flex-start;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 64px;
    height: min-content;
    justify-content: flex-start;
    overflow: hidden;
    padding: 0;
    position: relative;
    width: min-content;
    z-index: 2;
}

.logo-container {
    align-content: center;
    align-items: center;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 10px;
    height: min-content;
    justify-content: center;
    overflow: visible;
    padding: 0;
    position: relative;
    width: min-content;
}

.logo {
    display: block;
    flex: none;
    position: relative;
}

.logo-large {
    width: 360px;
    height: 45px;
}

.logo-small {
    display: none;
    width: 200px;
    height: 25px;
}

/* ===== CONTACT INFO ===== */
.contact-info {
    align-content: flex-start;
    align-items: flex-start;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 32px;
    height: min-content;
    justify-content: flex-start;
    overflow: visible;
    padding: 0;
    position: relative;
    width: min-content;
}

.contact-block {
    align-content: flex-start;
    align-items: flex-start;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0;
    height: min-content;
    justify-content: flex-start;
    overflow: visible;
    padding: 0;
    position: relative;
    width: min-content;
}

.contact-block:first-child {
    gap: 24px;
}

.separator {
    flex: none;
    width: 24px;
    height: 5px;
    background-color: var(--color-black);
    position: relative;
}

.contact-info p,
.contact-info a {
    font-family: var(--font-regular);
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    letter-spacing: 0px;
    line-height: 1.4em;
    color: var(--color-black);
    text-align: left;
    white-space: pre;
    flex: none;
    height: auto;
    position: relative;
    width: auto;
    text-decoration: none;
}

.contact-info a:hover {
    text-decoration: underline;
}

/* ===== HERO BACKGROUND (ZS Icon) ===== */
.hero-background {
    position: absolute;
    top: 0;
    left: 0;
    right: -25%;
    height: 1600px;
    overflow: hidden;
    z-index: 0;
    pointer-events: none;
}

.zs-icon {
    display: block;
    position: absolute;
    width: 200%;
    height: auto;
    right: -65%;
    top: -200%;
}

/* ===== AVV SECTION ===== */
.section-content {
    align-content: flex-start;
    align-items: flex-start;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0px;
    height: min-content;
    justify-content: flex-start;
    overflow: auto;
    padding: 0 0 120px 128px;
    position: relative;
    width: 100%;
}

.content-wrapper {
    align-content: flex-start;
    align-items: flex-start;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 32px;
    height: min-content;
    justify-content: flex-start;
    overflow: visible;
    padding: 0;
    position: relative;
    width: 75%;
    z-index: 1;
}

.avv-header {
    align-content: flex-start;
    align-items: flex-start;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0;
    height: min-content;
    justify-content: center;
    overflow: hidden;
    padding: 40px 0 0;
    position: relative;
    width: 100%;
}

.avv-header h3 {
    font-family: var(--font-bold);
    font-size: 24px;
    font-style: normal;
    font-weight: 400;
    letter-spacing: 0px;
    line-height: 1.4em;
    text-align: left;
    color: var(--color-black);
    flex: none;
    height: auto;
    position: relative;
    white-space: pre-wrap;
    width: 100%;
    word-break: break-word;
    word-wrap: break-word;
}

.avv-body {
    align-content: center;
    align-items: center;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0px;
    height: min-content;
    justify-content: center;
    overflow: hidden;
    padding: 0;
    position: relative;
    width: 100%;
}

.avv-body > * {
    margin: 16px 0;
}

.avv-body > :first-child {
    margin-top: 0;
}

.avv-body > :last-child {
    margin-bottom: 0;
}

.avv-section {
    align-content: flex-start;
    align-items: flex-start;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0px;
    height: min-content;
    justify-content: center;
    overflow: hidden;
    padding: 0;
    position: relative;
    width: 100%;
}

.avv-section > * {
    margin: 16px 0;
}

.avv-section > :first-child {
    margin-top: 0;
}

.avv-section > :last-child {
    margin-bottom: 0;
}

.avv-section h4 {
    font-family: var(--font-bold);
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    letter-spacing: 0px;
    line-height: 1.4em;
    text-align: left;
    color: var(--color-black);
    flex: none;
    height: auto;
    position: relative;
    scroll-margin-top: 240px;
    white-space: pre-wrap;
    width: 100%;
    word-break: break-word;
    word-wrap: break-word;
}

.avv-section p {
    font-family: var(--font-regular);
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    letter-spacing: 0px;
    line-height: 1.4em;
    text-align: left;
    color: var(--color-black);
    flex: none;
    height: auto;
    position: relative;
    white-space: pre-wrap;
    width: 100%;
    word-break: break-word;
    word-wrap: break-word;
}

/* ===== APPEAR ANIMATION ===== */
.hero-content,
.content-wrapper {
    opacity: 0;
    animation: fadeIn 0.75s cubic-bezier(0.44, 0, 0.56, 1) forwards;
}

.content-wrapper {
    animation-delay: 0.15s;
}

@keyframes fadeIn {
    from {
        opacity: 0.001;
    }
    to {
        opacity: 1;
    }
}

/* ==========================================================
   RESPONSIVE BREAKPOINTS
   Framer breakpoints:
   - >= 1920px: width 1920, gap 160, font 20px
   - 1512-1919: width 1512, gap 128, font 14px
   - 1280-1511: width 1280, gap 128, font 14px
   - 1024-1279: width 1024, gap 80, font 12px, small logo
   - <= 1023:   width 390, gap 96, font 12px, small logo
   ========================================================== */

/* ===== >= 1920px ===== */
@media (min-width: 1920px) {
    .page {
        max-width: 1920px;
    }

    .content-sections > * {
        margin: 80px 0;
    }
}

/* ===== 1200px - 1919px ===== */
@media (min-width: 1200px) and (max-width: 1919px) {
    .page {
        max-width: 100%;
    }

    .content-sections > * {
        margin: 64px 0;
    }
}

/* ===== <= 1199px (Tablet/Mobile) ===== */
@media (max-width: 1199px) {
    .logo-large {
        display: none;
    }

    .logo-small {
        display: block;
    }

    .content-sections > * {
        margin: 48px 0;
    }
}

/* ===== <= 768px (Mobile) ===== */
@media (max-width: 768px) {
    .hero-content {
        gap: 48px;
    }

    .section-content {
        padding: 0 24px;
    }

    .content-wrapper {
        width: 100%;
    }

    .contact-info p,
    .contact-info a {
        font-size: 14px;
    }

    .avv-section p,
    .avv-section h4 {
        font-size: 14px;
    }

    .avv-header h3 {
        font-size: 20px;
    }
}
