body, h1, h2, h3, h4, h5, h6, p, div, span, a, button {
    font-family: 'Montserrat', sans-serif !important;
}
a {
    text-decoration:none!important;
}
    a:hover {
        text-decoration:none;
    }
#blazor-error-ui {
    display: none !important;
}
/* Global reset */
body, html {
    margin: 0;
    padding: 0;
    height: 100%;
    font-family: 'Segoe UI', sans-serif;
    user-select:none!important;
}
:focus-visible {
    outline:none!important;
}
/* Layout wrapper */
/*.layout-wrapper {
    display: flex;
    position: fixed;
    top: 0;
    bottom: 0;
    width: 100%;
    z-index: 100;
    pointer-events: none;*/ /* allow clicks through */
/*}*/
/* Columns */
/*.layout-left,
.layout-right {
    flex: 0 0 50%;
    transition: transform 0.6s ease;
    pointer-events: auto;*/ /* clickable */
/*display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    padding: 2rem;
}

.layout-left {
    background: #222;
}

.layout-right {
    background: #444;
}*/
/* Sliding animations */
/*.slide-left-in {
    transform: translateX(0);
}

.slide-left-out {
    transform: translateX(-100%);
}

.slide-right-in {
    transform: translateX(0);
}

.slide-right-out {
    transform: translateX(100%);
}*/
/* Overlay content */
/*.overlay-content {
    text-align: center;
}

    .overlay-content h1 {
        font-size: 2rem;
        margin-bottom: 1rem;
    }*/
/* Menu */
/*.menu {
    list-style: none;
    padding: 0;
    margin: 0;
    text-align: center;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    min-width: 100%;
}

    .menu li {
        margin: 0;
        min-width: 100%;
        padding: 0;
        display:flex;
        justify-content: center;
        align-items: center;
    }

    .menu a {
        color: white;
        text-decoration: none;
        font-size: 1.2rem;
        transition: color 0.3s;
    }

        .menu a:hover {
            color: #ffcc00;
        }*/
/* Page content */
/*.page-content {
    position: relative;
    margin-left: auto;
    margin-right: auto;
    padding: 2rem;
    max-width: 90vw;
    opacity: 0;
    transition: opacity 0.6s ease;
    z-index: 50;
}

    .page-content.fade-in {
        opacity: 1;
    }*/
/* Wrapper */
.layout-wrapper {
    display: flex;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 100;
    pointer-events: none;
}
.overlay-content {
    background-color:white;
}
/* Panels */
.layout-left {
    flex: 0 0 75.00%; /* 6 of 12 */
    background: #000;
    /*overflow-y: auto;*/
    position: relative;
    pointer-events: auto;
    overflow:hidden;
}

.layout-right {
    flex: 0 0 25.00%;
    background-color: black;
    pointer-events: auto;
    position: sticky;
    top: 3.8rem;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    background-image: url(/images/bg.png);
    background-size: cover;
    overflow: hidden;
    background-position-x: center;
}
/*.layout-right {
    flex: 0 0 50%;*/ /* 6/12 */
    /*display: flex;
    align-items: stretch;*/ /* stretch full height */
    /*justify-content: center;
    height: 100vh;
    background: linear-gradient(135deg, #cfa34a, #b8860b);*/ /* goldish gradient */
    /*color: white;
}*/

/* Sliding animations */
.slide-left-in {
    transform: translateX(0);
}

.slide-left-out {
    transform: translateX(-100%);
}

.slide-right-in {
    transform: translateX(0);
}

.slide-right-out {
    transform: translateX(100%);
}

.layout-left,
.layout-right {
    transition: transform 0.6s ease;
}
/* Video background */
.bg-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
    opacity:0.3;
}

/* Overlay (logo + text) */
.left-overlay {
    position: relative;
    z-index: 2;
    color: white;
    text-align: center;
    padding: 2rem;
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 10% 10% 12% 8%;
    align-items: start;
    text-align: left;
}
@keyframes slideInLeft {
    from {
        transform: translateX(-100%);
        opacity: 0;
    }

    to {
        transform: translateX(0);
        opacity: 1;
    }
}
@keyframes slideInRight {
    from {
        transform: translateX(100%);
        opacity: 0;
    }

    to {
        transform: translateX(0);
        opacity: 1;
    }
}
/* Logo animation */
@keyframes slideInFromLeft {
    0% {
        opacity: 0;
        transform: translateX(-100%);
    }

    100% {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Base state */
.logo {
    opacity: 0; /* hidden until animated */
    transition: opacity 0.3s ease;
}

/* Active animation class */
.logo-animate {
    animation: slideInFromLeft 1s ease forwards;
}


.logo-container {
    /*max-height:25%;*/
    text-align:center;
    
}
.left-overlay .logo {
    max-width: 80%;
    
    /*animation: slideInLeft 0.8s ease-out forwards;*/
    /*margin-bottom: 1rem;*/
    /*margin-top:15%;*/
}
.year-container {
/*    font-size: 4rem;
    text-align: left;
    font-weight: bold;
    margin-left: 5%;*/
}
.year-container img{
    max-width:55%;
    /*margin-bottom:10%;*/
}
.year-text-container {
    text-align: left;
    font-size: 2.2rem;
    color: gray;
    margin-left: 5%;
    line-height: 5px;
}
.top-qut {
    font-size: 4rem;
    text-align: left;
    font-weight: bold;
    margin-left: 5%;
    max-height: 30px;
}
.down-qut {
    font-size: 4rem;
    text-align: right;
    font-weight: bold;
    margin-left: 5%;
    max-width: 575px;
    position: relative;
    top: -25px;
    max-height:20px;
}
.btn-outline-light {
    max-width: 130px;
    margin-left: 5%;
    background-color: #ac823a;
    font-weight: bold;
    padding: 10px;
    border-radius: 12px;
    border: none;
}
/* Menu */
.menu-container {
    display: flex;
    flex-direction: column;
    gap: 0rem;
    text-align: center;
    color: white;
    font-size: 1.5rem;
    min-height: 100vh;
    align-items: center;
    justify-content: space-around;
    width: 100%;
}

    .menu-container .content {
        cursor: pointer;
        transition: color 0.3s;
        min-height: 20vh;
        display: flex;
        align-items: center;
        width: 100%;
        justify-content: center;
        margin: 0;
        padding-left:5%;
        padding-right:5%;
    }

.nav-text {
    cursor: pointer;
    transition: color 0.3s;
    min-height: 20vh;
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: center;
    font-size:2.0rem;
    padding-left:5%;
    padding-right:5%;
    margin: 0;
    transition: all 0.6s ease;
    font-weight:500;
}
.nav-icon-container {
    padding: 0 1%;
    max-width: 15%;
    text-align: left;
    margin-left: 3%;
}
.nav-icon {
    margin: 10px;
    width: 85%;
    transition: transform 0.3s ease;
}
    .nav-icon:hover {
        transform: scale(1.3);
    }
.nav-text:hover {
    color: goldenrod;
}

/* Page content */
.page-content {
    position: relative;
    margin: 0 auto;
    padding: 0rem 2rem;
    /*max-width: 90vw;*/
    opacity: 0;
    transition: opacity 0.6s ease;
    z-index: 50;
}

    .page-content.fade-in {
        opacity: 1;
    }



/* Main container with spacing */
.page-container {
    padding: 2rem 6rem;
}
.inner-logo-container {
    background-color: white;
    z-index: 1;
    position: sticky;
    top: 0;
    padding-top: 1rem;
}
/* Left column (scrollable content) */
.page-left {
    /*padding-right: 2rem;*/
    flex: 0 0 75.00%;
    position:relative;
}

    .page-left section {
        margin-bottom: 4rem;
    }

    .page-left h1 {
        font-size: 2.2rem;
        margin-bottom: 2rem;
    }

    .page-left h2 {
        margin-top: 1rem;
        margin-bottom: 0.5rem;
        font-weight:bold;
        font-size:1.8rem;
    }

    .page-left .orange {
        color: orange;
    }

    .page-left .pink {
        color: deeppink;
    }

    .page-left .purple {
        color: purple;
    }

.icon-img {
    width: 80px;
    height: 80px;
    margin-bottom: 1rem;
}

/* Right column sticky */
.page-right {
    /*position: relative;*/
    flex: 0 0 25.00%
}

.sticky-card {
    position: sticky;
    align-items: start;
    justify-content: end;
    display: flex;
    flex-direction: column;
    top: 2rem;
    color: white;
    border-radius: 1rem;
    padding: 0rem;
    text-align: center;
    min-height: 85vh;
}

.vertical-text {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    font-size: 3.0rem;
    font-weight: bold;
    position: absolute;
    right: 0;
    bottom: 35%;
}
.page-icon-container {
    width: 100%;
    display: flex;
    align-items: end;
    justify-content:end;
}
.page-icon {
    margin: 10px;
    width: 40%;
    transition: transform 0.3s ease;
    opacity:0.5;
}
.return-home-btn {
    position: absolute;
    right: 10%;
    height: 30px;
    font-size: 2rem;
    text-decoration: none;
    font-weight: 500;
    color: white;
    top: 5%;
}

.icon-big {
    font-size: 4rem;
    margin: 2rem 0;
}

.nav-links {
    display: flex;
    justify-content: space-between;
    margin-top: 2rem;
    width: 100%;
    flex-direction: column;
    height: 25vh;
    font-size: 1.8rem;
    font-weight: 500;
}
.nav-links-container {
    display: flex;
    justify-content: space-between;
    /* margin-top: 2rem; */
    width: 100%;
    flex-direction: column;
    /* height: 9vh; */
    /* font-size: 1.2rem; */
    font-weight: 500;
    gap: 0rem;
}
.nav-links-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem;
    border-top: dotted 0.01rem lightgray;
}

.nav-links div {
    color: white;
    font-weight: 500;
    text-decoration: none;
    min-height:7vh;
}

        .nav-links div:hover {
            text-decoration: none;
            cursor:pointer;
            color:goldenrod;
        }




/*Mobile*/
.layout-wrapper-mob {
    display: flex;
    position: fixed;
    top: 0;
    /* bottom: 0; */
    left: 0;
    right: 0;
    max-width: 100vw;
    z-index: 100;
    pointer-events: none;
    flex-direction: column;
    overflow: scroll;
    height: 100%;
}
.layout-left-mob {
    flex: 0 0 50.00%;
    background: #000;
    /* overflow-y: auto; */
    position: sticky;
    pointer-events: auto;
    overflow: hidden;
    top:0;

}
.left-overlay-mob {
    position: relative;
    z-index: 2;
    color: white;
    text-align: center;
    padding: 2rem;
    height: 50vh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 10% 10% 12% 8%;
    align-items: start;
    text-align: left;
}
.layout-right-mob {
    flex: 0 0 85.00%;
    background-color: black;
    pointer-events: auto;
    position: sticky;
    top: 3.8rem;
    /*display: flex;*/
    justify-content: center;
    align-items: center;
    height: 100vh;
    background-image: url(/images/bg.png);
    background-size: cover;
    overflow: auto;
    background-position-x: center;
    max-height:50vh;
}
.layout-left-mob,
.layout-right-mob {
    transition: transform 0.6s ease;
}
.menu-container-mob {
    display: flex;
    flex-direction: column;
    gap: 0rem;
    text-align: center;
    color: white;
    font-size: 1.5rem;
    /* min-height: 100vh; */
    align-items: center;
    justify-content: space-around;
    width: 100%;
}
.menu-container-mob .content-mob {
    cursor: pointer;
    transition: color 0.3s;
    min-height: 14vh;
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: center;
    margin: 0;
    padding-left: 5%;
    padding-right: 5%;
}
.nav-text-mob {
    cursor: pointer;
    transition: color 0.3s;
    min-height: 14vh;
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: center;
    font-size: 1.6rem;
    padding-left: 5%;
    padding-right: 5%;
    margin: 0;
    transition: all 0.6s ease;
    font-weight: 500;
}
.page-content-mob {
    position: relative;
    margin: 0 auto;
    padding: 0rem 2rem;
    /* max-width: 90vw; */
    opacity: 0;
    transition: opacity 0.6s ease;
    z-index: 50;
}
.page-content-mob.fade-in {
    opacity: 1;
}

.page-container-mob {
    padding:0;
}
.sticky-card-mob {
    position: sticky;
    align-items: center;
    justify-content: center;
    display: flex;
    flex-direction: column;
    top: 2rem;
    color: white;
    padding: 0rem;
    text-align: center;
    min-height: 20vh;
}
.vertical-text-mob {
/*    writing-mode: vertical-rl;
    transform: rotate(180deg);
*/    font-size: 2.3rem;
    font-weight: 500;
    position: relative;
    top:0px;
    margin-top:15px;
}
.return-home-btn-mob {
    position: absolute;
    right: 5%;
    height: 30px;
    font-size: 1.5rem;
    text-decoration: none;
    font-weight: 500;
    color: white;
    top: 5%;
}

/* ---------- Lazy Loading Animation ---------- */
.lazy-card {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s ease;
}

    .lazy-card.visible {
        opacity: 1;
        transform: translateY(0);
    }
