@font-face {
    font-family: 'SVN-Gilroy';
    src: url(../fonts/SVN-Gilroy-Regular.eot);
    src: url(../fonts/SVN-Gilroy-Regular.eot?#iefix) format('embedded-opentype'), url(../fonts/SVN-Gilroy-Regular.woff) format('woff'), url(../fonts/SVN-Gilroy-Regular.ttf) format('truetype');
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'SVN-Gilroy';
    src: url(../fonts/SVN-Gilroy-SemiBold-Italic.eot);
    src: url(../fonts/SVN-Gilroy-SemiBold-Italic.eot?#iefix) format('embedded-opentype'), url(../fonts/SVN-Gilroy-SemiBold-Italic.woff) format('woff'), url(../fonts/SVN-Gilroy-SemiBold-Italic.ttf) format('truetype');
    font-weight: 600;
    font-style: italic;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    min-height: 100%;
}

body {
    font-family: 'Montserrat', 'SVN-Gilroy', system-ui, sans-serif;
    color: #fff;
    background: #1a1a4b;
}

body.coming-soon {
    position: relative;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    overflow-x: hidden;
}

.coming-soon__bg {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
}

.coming-soon__bg-photo {
    position: absolute;
    inset: 0;
    background-color: #1a1a4b;
    background-image: url('../images/bg.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.coming-soon__bg-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(26, 26, 75, 0.92) 0%,
        rgba(30, 30, 90, 0.88) 45%,
        rgba(45, 35, 100, 0.85) 100%
    );
}

.coming-soon__bg-shapes {
    position: absolute;
    inset: 0;
    opacity: 0.35;
    background:
        linear-gradient(115deg, transparent 40%, rgba(120, 100, 220, 0.25) 40%, rgba(120, 100, 220, 0.12) 65%, transparent 65%),
        linear-gradient(-35deg, transparent 55%, rgba(80, 120, 255, 0.08) 0);
}

.coming-soon__header,
.coming-soon__footer,
.coming-soon__main {
    position: relative;
    z-index: 1;
}

.coming-soon__header {
    flex-shrink: 0;
    padding: clamp(28px, 5vw, 50px);
}

.brand {
    display: inline-block;
    line-height: 0;
    text-decoration: none;
    color: inherit;
}

.brand__logo {
    display: block;
    height: clamp(40px, 12vw, 72px);
    width: auto;
    max-width: min(280px, 70vw);
    object-fit: contain;
    object-position: left center;
}

.coming-soon__main {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 24px clamp(20px, 6vw, 48px) 80px;
}

.coming-soon__title {
    margin: 0 0 1rem;
    line-height: 0;
}

.coming-soon__title-img {
    display: block;
    width: auto;
    max-width: min(92vw, 720px);
    height: auto;
    margin: 0 auto;
    filter: drop-shadow(0 4px 24px rgba(0, 0, 0, 0.35));
}

.coming-soon__lead {
    margin: 0;
    max-width: 42rem;
    font-size: clamp(0.95rem, 2.2vw, 1.125rem);
    font-weight: 400;
    line-height: 1.65;
    opacity: 0.95;
}

.coming-soon__footer {
    flex-shrink: 0;
    padding: 0 clamp(28px, 5vw, 50px) clamp(28px, 5vw, 50px);
}

.coming-soon__tagline {
    margin: 0;
    font-size: clamp(0.95rem, 2vw, 1.1rem);
    font-weight: 500;
    font-style: italic;
    max-width: 28rem;
}

@media (max-width: 480px) {
    .coming-soon__main {
        padding-bottom: 100px;
    }
}
