h1 {
    font-size: 1.69em;
    font-weight: 400;
}

.footer {
    background-color: #ffffff;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 5px;
}

/* cyrillic-ext */
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
font-stretch: 100%;
font-display: swap;
src: url(https://fonts.gstatic.com/s/opensans/v40/memSYaGs126MiZpBA-UvWbX2vVnXBbObj2OVZyOOSr4dVJWUgsjZ0B4taVIUwaEQbjB_mQ.woff2) format('woff2');
unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
font-stretch: 100%;
font-display: swap;
src: url(https://fonts.gstatic.com/s/opensans/v40/memSYaGs126MiZpBA-UvWbX2vVnXBbObj2OVZyOOSr4dVJWUgsjZ0B4kaVIUwaEQbjB_mQ.woff2) format('woff2');
unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
font-stretch: 100%;
font-display: swap;
src: url(https://fonts.gstatic.com/s/opensans/v40/memSYaGs126MiZpBA-UvWbX2vVnXBbObj2OVZyOOSr4dVJWUgsjZ0B4saVIUwaEQbjB_mQ.woff2) format('woff2');
unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
font-stretch: 100%;
font-display: swap;
src: url(https://fonts.gstatic.com/s/opensans/v40/memSYaGs126MiZpBA-UvWbX2vVnXBbObj2OVZyOOSr4dVJWUgsjZ0B4jaVIUwaEQbjB_mQ.woff2) format('woff2');
unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* hebrew */
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
font-stretch: 100%;
font-display: swap;
src: url(https://fonts.gstatic.com/s/opensans/v40/memSYaGs126MiZpBA-UvWbX2vVnXBbObj2OVZyOOSr4dVJWUgsjZ0B4iaVIUwaEQbjB_mQ.woff2) format('woff2');
unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
/* math */
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
font-stretch: 100%;
font-display: swap;
src: url(https://fonts.gstatic.com/s/opensans/v40/memSYaGs126MiZpBA-UvWbX2vVnXBbObj2OVZyOOSr4dVJWUgsjZ0B5caVIUwaEQbjB_mQ.woff2) format('woff2');
unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
font-stretch: 100%;
font-display: swap;
src: url(https://fonts.gstatic.com/s/opensans/v40/memSYaGs126MiZpBA-UvWbX2vVnXBbObj2OVZyOOSr4dVJWUgsjZ0B5OaVIUwaEQbjB_mQ.woff2) format('woff2');
unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* vietnamese */
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
font-stretch: 100%;
font-display: swap;
src: url(https://fonts.gstatic.com/s/opensans/v40/memSYaGs126MiZpBA-UvWbX2vVnXBbObj2OVZyOOSr4dVJWUgsjZ0B4vaVIUwaEQbjB_mQ.woff2) format('woff2');
unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
font-stretch: 100%;
font-display: swap;
src: url(https://fonts.gstatic.com/s/opensans/v40/memSYaGs126MiZpBA-UvWbX2vVnXBbObj2OVZyOOSr4dVJWUgsjZ0B4uaVIUwaEQbjB_mQ.woff2) format('woff2');
unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
font-family: 'Open Sans';
font-style: normal;
font-weight: 400;
font-stretch: 100%;
font-display: swap;
src: url(https://fonts.gstatic.com/s/opensans/v40/memSYaGs126MiZpBA-UvWbX2vVnXBbObj2OVZyOOSr4dVJWUgsjZ0B4gaVIUwaEQbjA.woff2) format('woff2');
unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
.goq-logo-nav {
    position: fixed;
    left: 10px;
    width: 35px;
    height: 35px;
    user-select: none;
    -webkit-tap-highlight-color: #00000000;
    margin-top: -5px;
}
.initial-loading {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #ffffff;
    z-index: 999999; /* large enough to cover everything */
    opacity: 100%;
    transition: .3s;
}
.fade-out {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #ffffff;
    z-index: 999999; /* large enough to cover everything */
    opacity: 0%;
    transition: .3s;
}
.goq-logo {
    position: relative;
    width: 300px;
    max-width: 60%;
    height: auto;
    user-select: none;
    z-index: 999;
    opacity: 100%;
    margin-bottom: 0px;
    margin-top: 50px;
}
.banner {
    position: relative;
    width: 100%;
    height: auto;
    user-select: none;
    z-index: 998;
    margin-bottom: 50px;
}
.banner-image {
    position: relative;
    width: 100%;
    height: auto;
    user-select: none;
    opacity: 55%;
    z-index: 997;
}
.content-wrapper {
    display: flex;
    justify-content: center;
    height: 100%; /* Full viewport height */
    width: 100%;
}
.content {
    text-align: left;
    max-width: 600px;
}
.content-block-1 {
    color: #131d20d1;
    padding: 20px;
    margin-top: -30px;
}

.navbar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    background-color: #ffffff;
    color: white;
    text-align: center;
    padding: 10px;
    font-size: 1.2em;
    z-index: 9999;
    margin: 0;
    overflow-wrap: break-word;
}

.navbutton {
    display: inline-block;
    width: 60px;
    cursor: pointer;
    color: #131d20d1;
    text-decoration: none;
    font-size: small;
    padding: 5px;
    margin: 2px;
    border-radius: 5px;
    /* border: 1px solid #ffffff; */
    border-radius: 5px;
    box-shadow: 0 0px 2px rgba(0, 0, 0, 0.092);
}
/* .navbutton:hover {
    border: 1px solid #0095ff;
} */

.tagline {
    max-width: 90%;
    margin: 0px;
    color: #131d20d1;
    font-size: xxx-large;
}

* {
    box-sizing: border-box;
    font-family: Helvetica, Arial, sans-serif;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
}
html {
    background-color: #ffffff;
    width: 100%;
    height: auto;
    overflow-y: scroll;
}
body {
    background-color: #ffffff;
    font-family: Helvetica, Arial, sans-serif;
    font-size: medium;
    margin: 0px;
    margin-top: 0px;
    padding-bottom: 100px;
    width: 100%;
    height: 100%;
    color: #131d20d1;
}
button {
    color: #131d20d1;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    border: 1px solid #0095ff00;
    outline: 1px solid #0095ff00;
    border-radius: 3.33px;
}
button:focus {
    color: #131d20d1;
    border-radius: 3.33px;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    border: 1px solid #0095ff;
    outline: 1px solid #0095ff;
}
textarea {
    resize: none;
    height: auto;
    min-height: 100px;
}
.form-container {
    margin: 0 auto;
    padding: 20px;
    border-radius: 3.33px;
}

.form-container input,
.form-container textarea {
    color: #131d20d1;
    width: 100%;
    margin-bottom: 10px;
    border: 1px solid #ccccccab;
    border-radius: 3.33px;
    height: 25px;
    line-height: 25px;
    font-size: x-small;
    padding-left: 5px;
    outline: 1px solid #0095ff00; /* Match submit button focus */
}
.form-container input:focus,
.form-container textarea:focus {
    border: 1px solid #ccccccab;
    outline: 1px solid #ccccccab;
}
/*
.form-container input[type="submit"] {
    background-color: #0095ff;
    color: white;
    cursor: pointer;
    border: 1px solid #0095ff00;
    outline: 1px solid #0095ff00;
    width: auto;
    float: left;
    text-align: center;
    align-items: center;
    vertical-align: middle;
}

.form-container input[type="submit"]:focus {
    border: 1px solid #0095ff00;
    outline: 1px solid #0095ff00;
}
*/
.contact-header {
    margin-bottom: 30px;
    font-size: 12px;
    color: #131d20d1;
}

.contact-header-subtext {
    padding-left: 2px;
    font-size: 10px;
    color: #131d20d1;
}
.field-spacer {
    width: 100%;
    height: 5px;
}
.no-select {
    user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -webkit-user-select: none;
}
input, textarea, .content-block-1 {
    user-select: text;
}

/* Added from glass_morphism.html */
.glass-container { /* Renamed from body for perspective */
    display: flex;
    justify-content: center;
    align-items: center;
    perspective: 1500px;
    padding-top: 0px;
    padding-bottom: 20px;
}

.glass {
    position: relative;
    width: fit-content; /* Adjusted for responsiveness */
    height: fit-content; /* Adjusted height */
    background: rgba(255, 255, 255, 0.1);
    border-radius: 5px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.094);
    border: 1px solid rgba(255, 255, 255, 0.3);
    transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
    transform-style: preserve-3d;
    padding: 10px;
}

.glass img { /* Scoped to img within .glass */
    width: 100%;
    max-width: 1600px;
    height: auto;
    opacity: 0.9;
    border-radius: 5px; /* Match parent's border radius */
    position: relative;
    z-index: 0;
}
/* End of added CSS */

/* New styles for side-by-side content glass blocks */
.content-blocks-wrapper {
    text-align: center; /* To center the inline-blocks */
    margin: 20px;
    max-width: 1600px !important;
}

.content-glass-block {

    width: calc(50% - 12px); /* Adjust width to fit two side-by-side with margins */

        
    display: inline-block;
    height: auto;
    min-width: 260px; /* Min width before content gets too cramped */
    max-width: 705px !important;
    min-height: 347px;
    margin-left: 0px;
    margin-right: 5px;
    margin-bottom: 20px;
    padding: 30px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 5px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.094);
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: #131d20d1;
    vertical-align: top;
    text-align: left;
    overflow: auto; /* In case content overflows the square */
    box-sizing: border-box;
    justify-content: center;
    align-items: center;
    /* Added for scroll animation */
    opacity: 0;
    transform: translateY(50px); /* Start 50px down */
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.content-glass-static {
    width: 100%;
    display: block;
    height: auto;
    min-width: 260px; /* Min width before content gets too cramped */
    max-width: 1600px !important;
    min-height: 180px;
    margin-left: 0px;
    margin-bottom: 20px;
    margin-top: 0px;
    padding: 30px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 5px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.094);
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: #131d20d1;
    text-align: left;
    overflow: auto; /* In case content overflows the square */
    box-sizing: border-box;
    justify-content: center;
    align-items: center;
    /* Added for scroll animation */
    opacity: 1;
}

/* Added for scroll animation - final state */
.content-glass-block.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (max-width: 768px) {
    .content-glass-block {
        width: 100%; /* Adjust width to fit two side-by-side with margins */
        max-width: 49.5%; /* Ensure it doesn't exceed 49% as per request */
    }
}
/* End of new styles for content glass blocks */

.signup-button {
    display: block;
    float: left;
    width: fit-content;
    margin: 20px;
    margin-top: 0px;
    padding: 0 15px; /* Adjusted for height and line-height */
    height: 25px; /* To match form input height */
    line-height: 25px; /* To match form input line-height */
    background-color: #0095ff; /* Match submit button */
    color: white !important;
    border: 1px solid #0095ff00 !important; /* Match submit button focus */
    outline: 1px solid #0095ff00 !important; /* Match submit button focus */
    border-radius: 3.33px; /* Match submit button */
    cursor: pointer;
    font-size: x-small !important; /* Match submit button font size */
    text-decoration: none !important;
    transition: background-color 0.3s;
}
.signup-button:focus {
    border: 1px solid #0095ff00 !important; /* Match submit button focus */
    outline: 1px solid #0095ff00 !important; /* Match submit button focus */
}

.social-logo {
    width: 20px;
    height: 20px;
    margin: 5px;
}

/* Photo Carousel Styles */
.carousel-container {
    width: 100%;
    max-width: 1600px;
    margin: 20px auto;
    position: relative;
}

.carousel-wrapper {
    position: relative;
    width: 100%;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 5px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.094);
    border: 1px solid rgba(255, 255, 255, 0.3);
    overflow: hidden;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.carousel-slides {
    position: relative;
    width: 100%;
    height: 400px;
    overflow: hidden;
}

.carousel-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.6s ease-in-out;
    display: flex;
    justify-content: center;
    align-items: center;
}

.carousel-slide.active {
    opacity: 1;
}

.carousel-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 5px;
    user-select: none;
}

.carousel-navigation {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    display: flex;
    justify-content: space-between;
    padding: 0 20px;
    z-index: 10;
}

.carousel-btn {
    background: rgba(255, 255, 255, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.3) !important;
    border-radius: 50% !important;
    width: 40px;
    height: 40px;
    color: #131d20d1;
    font-size: 18px;
    font-weight: bold;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    transition: all 0.3s ease;
    user-select: none;
}

.carousel-btn:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: scale(1.1);
}

.carousel-btn:focus {
    outline: 1px solid rgba(255, 255, 255, 0.5);
    outline-offset: 2px;
}

.carousel-indicators {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
    z-index: 10;
}

.indicator {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.3);
    background: rgba(255, 255, 255, 0.2);
    cursor: pointer;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.indicator.active {
    background: rgba(255, 255, 255, 0.6);
    transform: scale(1.2);
}

.indicator:hover {
    background: rgba(255, 255, 255, 0.4);
}

/* Responsive adjustments for carousel */
@media (max-width: 768px) {
    .carousel-slides {
        height: 250px;
    }
    
    .carousel-navigation {
        padding: 0 10px;
    }
    
    .carousel-btn {
        width: 35px;
        height: 35px;
        font-size: 16px;
    }
    
    .indicator {
        width: 10px;
        height: 10px;
    }
}

@media (max-width: 480px) {
    .carousel-slides {
        height: 200px;
    }
    
    .carousel-btn {
        width: 30px;
        height: 30px;
        font-size: 14px;
    }
    
    .carousel-indicators {
        bottom: 15px;
        gap: 8px;
    }
}
