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

*{
    margin: 0;
    padding: 0;
}

ul[role='list'], ol[role='list']{
    list-style: none;
}

html:focus-within{
    scroll-behavior: smooth;
}

a:not([class]){
    text-decoration-skip-ink: auto;
}

img, picture, svg, video, canvas{
    max-width: 100%;
    height: auto;
    vertical-align: middle;
    font-style: italic;
    background-repeat: no-repeat;
    background-size: cover;
}

input, button, textarea, select{
    font: inherit;
}

@media (prefers-reduced-motion: reduce){
    html:focus-within {
        scroll-behavior: auto;
    }
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
        transition: none;
    }
}

body, html{
    height: 100%;
    scroll-behavior: smooth;
}

body{
    width: 100%;
    margin: 0;
    padding: 0;
    font-size: 13px;
    line-height: 1.3;
    border: 0;
    font-family: BarlowCondensed, sans-serif;
    letter-spacing: .05em;
    background-color: #000;
    background-image: url(../images/background.jpg);
    background-repeat: no-repeat;
    background-position: top center;
    background-attachment: fixed;
    background-size: cover;
    color:#fff;
}

#generationPreview,
#generationPreview2{
    width: 20vw;
    border: 5px solid rgba(255, 255, 255, 0.5);
}

[placeholder]:empty::before {
    content: attr(placeholder);
    opacity: 0.1;
    color: #fff;
}

[placeholder]:empty:focus::before {
    content: "";
}

.container{
    max-width: 1100px;
    margin:0 auto;
    text-align: center;
    display: flex;
    flex-flow:column;
    height: 100%;
    align-items: center;
    justify-content: start;
    padding-top: 5vh;
}

.body{
    height: 58vh;
    display: flex;
    align-items: center;
}

.body.body-step1{
    height: 80vh;
}
.body.body-step2{
    height: 80vh;
}
.body.body-step3{
    height: 80vh;
}

#settlement-name{
    background:transparent;
    border:0;
    outline:0;
    color:#fff;
    font-weight: 600;
    text-transform: uppercase;
    white-space: nowrap;
    font-size: 7.3rem;
    letter-spacing: 17px;
    font-family: 'Barlow Condensed';
    font-weight: 600;
}
#settlement-text{
    color:#fff;
    font-size: 7.3rem;
    letter-spacing: 17px;
    font-family: 'Barlow Condensed';
    font-weight: 600;
}

.header img.logo{
    margin-bottom: 15px;
}

.footer{
    bottom: 0;
    padding-bottom: 15px;
}

.footer a{
    color: #fff;
    text-decoration: none;
    font-family: 'Barlow Condensed';
    letter-spacing: 13px;
    font-weight: 500;
    font-size: 18px;
}

.footer .supplier-icons{
    display: flex;
    align-items: center;
    justify-content: center;
    gap:30px;
    margin-bottom: 15px;
}

.footer img{
    filter: brightness(0) saturate(100%) invert(97%) sepia(73%) saturate(2%) hue-rotate(226deg) brightness(111%) contrast(100%);
    opacity: 0.5;
}

.footer a:nth-child(1) img{
    width:5vw;
}
.footer a:nth-child(2) img{
    width: 3.5vw;
}
.footer a:nth-child(3) img{
    width: 2vw;
}
.footer a:nth-child(4) img{
    width: 6vw;
}
.footer a:nth-child(5) img{
    width:7.5vw;
}
.footer a:nth-child(6) img{
    width:6vw;
}

#settlement-name,
#settlement-text{
    background:
            url('../images/textpattern.png')
            no-repeat center center;
    background-size:100%;
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    caret-color: #fff;
    line-height: 1;
}

.move-to-step-3,
.move-to-step-2{
    border-radius: 45px;
    background: transparent;
    margin:0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: 'Crimson Pro', sans-serif;
    font-size:18px;
    font-weight: 600;
    gap:10px;
    letter-spacing: 3px;
    max-width: 320px;
    margin-top: 20px;
}

.move-to-step-2 .button,
.move-to-step-3 .button{
    cursor:pointer;
    background: transparent url(../images/buttonNT1.png) 0 0 no-repeat;
    background-size: cover;
    width:297px;
    height:58px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 23px;
    text-transform: uppercase;
    letter-spacing: 2px;
}

.move-to-step-3 .button:hover,
.move-to-step-2 .button:hover{
    background: transparent url(../images/buttonNT2.png) 0 0 no-repeat;
    background-size: cover;
}
.generated-image-container{
    margin-bottom: 25px;
}

.reset-image-settings{
    margin-top: 15px;
    font-family: 'Crimson Pro', sans-serif;
    letter-spacing: 3px;
    cursor: pointer;
    font-size: 16px;
}

.reset-icon{
    position: relative;
    top:5px;
    left:8px;
}
.reset-icon:before,
.reset-icon:after{
    content:'';
    background: #d46031;
    width:3px;
    height:10px;
    transform:rotate(45deg);
    display: block;
    position: absolute;
    top:0;
    left:0;
}
.reset-icon:before{
    transform:rotate(-45deg);
}

.download-section-buttons{
    display: flex;
    gap: 20px;
    align-items: center;
    justify-content: center;
    margin-top: 15px;
    margin-bottom: 10px;
}

.download-section a{
    width: 80px;
    height: 80px;
    background: transparent;
    text-decoration: none;
    color:#fff;
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: end;
    gap:5px;
    line-height: 1.1;
    font-size: 10px;
}
.download-section a:hover img:nth-child(1){
    display: none;
}
.download-section a:hover img:nth-child(2){
    display:block !important;
}
.square,
.cover,
.stories{
    background:#fff;
    display: block;
}

.square{
    width:27px;
    height: 27px;
}

.cover{
    width: 46px;
    height: 15px;
}

.stories{
    width: 20px;
    height: 36px;
}

.save-and-share{
    font-family: 'Crimson Pro', sans-serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 3px;
}

.footer a:nth-last-child(1) img {
    filter:none;
}

.footer a:hover img{
    opacity: 0.85;
}

.website a{
    opacity: 0.5;
}
.website a:hover{
    opacity: 0.85;
}

.legal{
    margin-top:10px;
}

.legal span,
.legal a{
    color: #fff;
    text-decoration: none;
    letter-spacing: 2px;
    font-weight: 100;
    font-size: 9px;
    font-family: 'Crimson Pro', sans-serif;
    opacity: 0.6;
}

.legal a:hover{
    opacity: 0.85;
}

.footer {
    padding-bottom: 2vh;
}

.website{
    margin-bottom: 20px;
}

@media(max-width: 1920px) and (min-width: 1199px){
    .header img.logo {
        max-width: 600px;
    }
    .body.body-step1,
    .body.body-step2,
    .body.body-step3{
        min-height: 600px;
    }
}

@media(min-width: 1921px) {
    .website{
        margin-bottom: 30px;
    }
    .move-to-step-3,
    .move-to-step-2{
        scale:1.34;
    }
    .move-to-step-3, .move-to-step-2{
        border-radius: 90px;
        font-size: 36px;
        gap:20px;
        letter-spacing: 6px;
    }
    .container{
        max-width: 2200px;
        padding-top: 6.1vh;
    }
    .header img.logo {
        margin-bottom: 14px;
    }
    #settlement-name, #settlement-text{
        font-size: 11rem;
        letter-spacing: 21px;
    }
    .reset-icon:before, .reset-icon:after{
        width: 6px;
        height: 20px;
    }
    .body.body-step1 {
        height: 80vh;
        min-height: 875px;
    }
    .body.body-step2{
        height: 80vh;
        min-height: 875px;
    }
    .body.body-step3{
        height: 80vh;
        min-height: 875px;
    }
    .move-to-step-2{
        margin-top: 35px;
    }
    .move-to-step-3{
        margin-top: 35px;
    }
    .footer a{
        font-size: 24px;
        letter-spacing: 17px;
        font-weight: 500;
    }
    .legal span,
    .legal a{
        letter-spacing: 0;
        font-size: 0.8rem;
        font-weight: 100;
    }
    .reset-icon {
        position: relative;
        top: -19px;
        left: 16px;
    }
    .download-section-buttons{
        gap:60px;
    }
    .reset-image-settings{
        font-size: 24px;
        margin-top: 35px;
    }
    .download-section a{
        scale: 1.34;
    }
    .save-and-share{
        font-family: 'Crimson Pro', sans-serif;
        font-size:30px;
        letter-spacing: 5px;
        margin-top: 15px;
        margin-bottom: 35px;
    }

    .square{
        width: 54px;
        height: 54px;
    }

    .cover{
        width: 92px;
        height: 30px;
    }

    .stories{
        width: 40px;
        height: 72px;
    }
    .footer .supplier-icons{
        gap:60px;
    }
    .subimage{
        scale:1.34;
    }
    .header{
        display: flex;
        flex-flow: column;
        gap: 40px;
    }
    .logo{
        scale:1.34;
    }
    #generationPreview, #generationPreview2{
        width: 20vw;
        width:512px;
    }
}

@media(min-width: 2561px){
    .body.body-step1 {
        height: 74vh;
        min-height: 1150px;
    }
    .body.body-step2 {
        height: 74.5vh;
        min-height: 1150px;
    }
    .body.body-step3 {
        height: 74.5vh;
        min-height: 1150px;
    }
    .move-to-step-3,
    .move-to-step-2{
        scale:2;
    }
    .move-to-step-3, .move-to-step-2{
        border-radius: 90px;
        font-size: 36px;
        gap:20px;
        letter-spacing: 6px;
    }
    .move-to-step-3 {
        margin-top: 85px;
    }
    .move-to-step-2 {
        margin-top:70px;
    }
    .container{
        max-width: 2200px;
    }
    .header img.logo {
        margin-bottom: 3.1vh;
    }
    #settlement-name, #settlement-text{
        font-size: 16rem;
        font-weight: 700;
        letter-spacing: 33px;
    }
    .reset-icon:before, .reset-icon:after{
        width: 6px;
        height: 20px;
    }
    .body {
        height: 72vh;
    }
    .footer a{
        font-size: 36px;
        letter-spacing: 26px;
        font-weight: 500;
    }
    .legal span,
    .legal a{
        letter-spacing: 3px;
        font-size: 1rem;
        font-weight: 300;
    }
    .website{
        margin-bottom: 40px;
    }
    .footer{
        padding-bottom: 2vh;
    }
    .reset-icon {
        position: relative;
        top: -19px;
        left: 16px;
    }
    .reset-image-settings{
        font-size: 40px;
        margin-top: 70px;
    }
    .download-section-buttons{
        gap: 140px;
    }
    .download-section a{
        scale:2;
    }
    .save-and-share{
        font-family: 'Crimson Pro', sans-serif;
        font-size:50px;
        letter-spacing: 5px;
        margin-bottom: 70px;
    }

    .square{
        width: 54px;
        height: 54px;
    }

    .cover{
        width: 92px;
        height: 30px;
    }

    .stories{
        width: 40px;
        height: 72px;
    }
    .footer .supplier-icons{
        gap:60px;
        margin-bottom: 15px;
    }
    .subimage{
        scale:2;
    }
    .header{
        display: flex;
        flex-flow: column;
        gap: 40px;
    }
    .logo{
        scale:2;
    }
    #generationPreview, #generationPreview2{
        width: 20vw;
        width: 772px;
    }
    .container{
        padding-top:7.2vh;
    }
}

@media(max-width: 1700px){
    #generationPreview, #generationPreview2{
        width: 22vw;
    }
}

@media(max-width: 1440px){
    #generationPreview, #generationPreview2{
        width: 24vw;
    }
}

@media(max-width: 1300px) {
    #generationPreview, #generationPreview2{
        width: 26vw;
    }
    .footer a:nth-child(1) img {
        width: 7vw;
    }

    .footer a:nth-child(2) img {
        width: 5.5vw;
    }

    .footer a:nth-child(3) img {
        width: 2.5vw;
    }

    .footer a:nth-child(4) img {
        width: 10.5vw;
    }

    .footer a:nth-child(5) img {
        width: 7vw;
    }
    #settlement-name,
    #settlement-text{
        font-size: 5rem;
        letter-spacing: 7px;
    }
}

@media(max-width: 1100px) {
    #generationPreview, #generationPreview2{
        width: 28vw;
    }
    .footer a:nth-child(1) img {
        width: 9vw;
    }

    .footer a:nth-child(2) img {
        width: 7.5vw;
    }

    .footer a:nth-child(3) img {
        width: 3vw;
    }

    .footer a:nth-child(4) img {
        width: 12.5vw;
    }

    .footer a:nth-child(5) img {
        width: 9vw;
    }
}

@media(max-width: 991px) {
    .body{
        min-height: 1100px;
    }
    .body.body-step1 {
        height: 80vh;
    }
    .body.body-step2 {
        height: 80vh;
    }
    .body.body-step3 {
        height: 80vh;
        margin-top: 5vh;
    }
    .legal span, .legal a{
        font-size: 12px;
    }
    .generated-image-container{
        margin: 0 auto 15px;
        display: flex;
        max-width: 80%;
    }
    #generationPreview, #generationPreview2 {
        width: auto;
        max-height: 100%;
        align-self: end;
    }
    .move-to-step-2{
        scale:1.34;
        margin-top:20px;
    }
    .move-to-step-3{
        scale:1.34;
        margin-top:40px;
    }
    .download-section-buttons{
        gap:50px;
    }
    .download-section a{
        scale:1.34;
    }
    .save-and-share,
    .reset-image-settings{
        max-width: 320px;
        margin: 0 auto;
        scale:1.34;
        margin-top: 30px;
    }
    .reset-image-settings{
        margin-top:40px;
    }
    .save-and-share{
        margin-bottom: 40px;
    }
    .footer a:nth-child(1) img {
        width: 11vw;
    }

    .footer a:nth-child(2) img {
        width: 9.5vw;
    }

    .footer a:nth-child(3) img {
        width: 3.5vw;
    }

    .footer a:nth-child(4) img {
        width: 14.5vw;
    }

    .footer a:nth-child(5) img {
        width: 13vw;
    }

    .footer a:nth-child(6) img {
        width: 13vw;
    }
}

@media(max-width: 767px) {
    .save-and-share, .reset-image-settings,
    .move-to-step-2,
    .move-to-step-3,
    .download-section a{
        scale:1;
    }
    .save-and-share {
        margin-bottom: 15px;
    }
    .generated-image-container {
        width: 65%;
    }
    .save-and-share, .reset-image-settings,
    .move-to-step-2,
    .move-to-step-3 {
        margin-top: 20px;
    }
    .download-section-buttons {
        gap: 20px;
    }
    .logo{
        max-width: 90%;
    }
    #settlement-text,#settlement-name{
        font-size: 45px;
        letter-spacing: 5px;
    }
    .footer a:nth-child(1) img {
        width: 13vw;
    }

    .footer a:nth-child(2) img {
        width: 11.5vw;
    }

    .footer a:nth-child(3) img {
        width: 4.25vw;
    }

    .footer a:nth-child(4) img {
        width: 16.5vw;
    }

    .footer a:nth-child(5) img {
        width: 13vw;
    }
}

@media(max-width: 480px) {
    #settlement-text,#settlement-name{
        font-size: 30px;
        letter-spacing: 3px;
    }
    .footer a:nth-child(1) img {
        width: 13vw;
    }

    .footer a:nth-child(2) img {
        width: 11.5vw;
    }

    .footer a:nth-child(3) img {
        width: 4.25vw;
    }

    .footer a:nth-child(4) img {
        width: 16.5vw;
    }

    .footer a:nth-child(5) img {
        width: 13vw;
    }

    .footer a:nth-child(6) img {
        width: 13vw;
    }
}