@font-face {
    font-family: 'NVIDIASans-Bold';
    src: url('../font/NVIDIASans-Bold.woff2') format('woff2'),
        url('../font/NVIDIASans-Bold.woff') format('woff'),
        url('../font/NVIDIASans-Bold.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'NVIDIASans-Light';
    src: url('../font/NVIDIASans-Light.woff2') format('woff2'),
        url('../font/NVIDIASans-Light.woff') format('woff'),
        url('../font/NVIDIASans-Light.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'NVIDIASans-Regular';
    src: url('../font/NVIDIASans-Regular.woff2') format('woff2'),
        url('../font/NVIDIASans-Regular.woff') format('woff'),
        url('../font/NVIDIASans-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}





*{
    box-sizing: border-box;
}

html {
    background-color: #000;
    accent-color: #76b900;
}

body {
    font-size: 16px;
    color: #fff;
    font-family: 'NVIDIASans-Regular';
    font-optical-sizing: auto;
    overflow-x: hidden
}

body h1,
body h2,
body h3,
body h4 {
    font-family: 'NVIDIASans-Bold';
    line-height: 1;
}

.container {
    max-width: 1348px;
    margin: 0 auto
}

.flex {
    clear: both;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-evenly
}

.center {
    justify-content: center
}

.between {
    justify-content: space-between
}

.gap {
    gap: 30px;
}

.wrap {
    flex-wrap: wrap;
}

footer {
    background-color: #000
}

footer p {
    color: #9e9e9e;
    font-size: 0.7rem;
    text-align: center;
    text-transform: uppercase;
    padding: 20px 0;
    text-wrap: balance;
}

main .container{
    background: url(../img/bg-topo.webp) center top no-repeat;
    background-size: cover;
    padding: 100px 50px;
}

main .texto{
    max-width: 460px;
}

h1{
    color: #fff;
    margin-bottom: 30px;
    font-size: 2rem;
}

main h2{
    color: #fff;
    margin-bottom: 30px;
    font-size: 1.6rem;
}

main p{
    margin-bottom: 30px;
}

main .flex{
    justify-content: flex-start;
}

#blackwell{
    padding: 50px 0;
    text-align: center;
}

#blackwell h2{
    font-size: 1.4rem;
    color: #fff;
    margin-bottom: 30px;
}

#blackwell h3{
    font-size: 2rem;
    color: #fff;
    margin-bottom: 30px;
}

#blackwell .texto{
    text-align: left;
}

#blackwell .texto h4{
    font-size: 1.4rem;
    color: #fff;
}

#blackwell .texto p{
    font-size: 1;
    color: #fff;
    margin-bottom: 30px;
}

#icones{
    padding: 50px 0;
    text-align: center;
}

#icones .flex{
    align-items: stretch;
}

#icones .box{
    max-width: 250px;
    background: #1a1a1a;
    padding: 30px;
    transition: all 0.3s;
}

#icones .box:hover{
    translate: 0 -10px;
}

#icones .box img{
    margin-bottom: 20px;
}

#icones .box h3{
    margin-bottom: 20px;
    color: #fff;
    font-size: 1.4rem;
}

#rtxon .container{
    padding: 50px 0;
    text-align: center;
}

#rtxon h2{
    font-size: 1.4rem;
    color: #fff;
    margin-bottom: 30px;
}

#rtxon h3{
    font-size: 2rem;
    color: #fff;
    margin-bottom: 30px;
}

#rtxon p{
    max-width: 800px;
    text-wrap: balance;
    margin: 0 auto 30px;
}

#dlss4 .container{
    background: url(../img/bg-03.webp) center top no-repeat;
    background-size: cover;
    padding: 100px 50px;
}

#dlss4 .texto{
    max-width: 460px;
}

#dlss4 h2{
    color: #fff;
    margin-bottom: 30px;
    font-size: 2rem;
}

#dlss4 h3{
    color: #fff;
    margin-bottom: 30px;
    font-size: 1.6rem;
}

#dlss4 p{
    margin-bottom: 30px;
}

#raytracing{
    padding: 50px 0;
    text-align: center;
}

#raytracing h2{
    font-size: 1.4rem;
    color: #fff;
    margin-bottom: 30px;
}

#raytracing h3{
    font-size: 2rem;
    color: #fff;
    margin-bottom: 30px;
}

#raytracing p{
    color: #fff;
    max-width: 960px;
    margin: 0 auto 30px;
}

#raytracing .flex *{
    transition: all 0.3s;
}

#raytracing .flex:has(:hover) :not(:hover)  {
    opacity: 0.5;
    filter: blur(2px);
}

#reflex2 .container{
    background: url(../img/bg-04.webp) center top no-repeat;
    background-size: cover;
    padding: 150px 50px;
}

#reflex2 .texto{
    max-width: 460px;
}

#reflex2 h2{
    color: #fff;
    margin-bottom: 30px;
    font-size: 2rem;
}

#reflex2 h3{
    color: #fff;
    margin-bottom: 30px;
    font-size: 1.6rem;
}

#ia{
    background: url(../img/bg-05.webp) center top no-repeat;
    background-size: cover;
    padding: 150px 50px;
}

#ia .texto{
    max-width: 460px;
}

#ia h2{
    color: #fff;
    margin-bottom: 30px;
    font-size: 2rem;
}

#ia h3{
    color: #fff;
    margin-bottom: 30px;
    font-size: 1.6rem;
}

#criadores .bg{
    background: url(../img/bg-06.webp) center top no-repeat;
    background-size: cover;
    padding: 150px 50px;
}

#criadores .texto{
    max-width: 460px;
}

#criadores h2{
    color: #fff;
    margin-bottom: 30px;
    font-size: 2rem;
}

#criadores h3{
    color: #fff;
    margin-bottom: 30px;
    font-size: 1.6rem;
}

#criadores .flex{
    align-items: stretch;
    translate: 0 -80px;
}

#criadores .box{
    max-width: 250px;
}

#criadores .box img{
    margin-bottom: 20px;
}

#criadores .box h3{
    font-size: 1.4rem;
    margin-bottom: 20px;
    color: #fff;
}

#criadores .box h4{
    font-size: 0.8rem;
    margin-bottom: 20px;
    color: #fff;
}

#recursos{
    padding: 50px 0;
    text-align: center;
}

#recursos h2{
    font-size: 2rem;
    color: #fff;
    margin-bottom: 30px;
}

#recursos h3{
    font-size: 1.4rem;
    color: #fff;
    margin-bottom: 30px;
    padding: 30px 30px 0;
}

#recursos p{
    color: #fff;
    padding: 0 30px;
}

#recursos .flex{
    gap: 50px;
    margin-bottom: 50px;
    align-items: stretch;
}

#recursos .flex:last-child{
    margin-bottom: 0;
}


#recursos .box{
    max-width: 380px;
    background: #1a1a1a;
    padding: 0 0 30px;
}

#logosfooter .container{
    padding: 50px 0;
    border-top: solid 1px #9e9e9e;
}

.mobile{
    display: none;
}

#form{
    padding: 50px 0;
    text-align: center;
}

#form h2{
    font-size: 2rem;
    color: #fff;
    margin-bottom: 30px;
}

#aniversario{
    display: none;
}

form{
    max-width: 800px;
    margin: 0 auto;
}

input{
    width: 100%;
    padding: 10px;
    border: #76b900 solid 1px;
    background: none;
    color: #fff;
    margin-bottom: 20px;
    font-size: 0.9rem;
}

input[type=submit]{
    background: #76b900;
    width: fit-content;
    margin: 0 auto;
    padding: 20px;
    text-transform: uppercase;
    font-family: 'NVIDIASans-Bold';
    cursor: pointer;
    transition: all 0.3s;
}

input[type=submit]:hover{
    background: #000;
}


::placeholder {
    color: #fff;
    opacity: 1;
  }
  
  ::-ms-input-placeholder { 
    color: #fff;
  }

  .legal{
    font-size: 0.7rem;
    text-align: left;
    margin-bottom: 10px;
  }

  .legal a{
    color: #76b900;
  }
  

  .datas{
    gap: 10px;
  }

  label{
    margin-bottom: 10px;
    display: block;
    text-align: left;
    font-size: 0.9rem;
  }

  .datas select{
    flex-grow: 1;
    padding: 10px;
    border: #76b900 solid 1px;
    background: none;
    color: #fff;
    margin-bottom: 20px;
    font-size: 0.9rem;
  }

  .boxcheckbox{
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
  }

  .boxcheckbox input{
    flex-grow: 0;
    width: auto;
    margin: 0;
  }

  .boxcheckbox label{
    margin: 0;
  }

  option{
    background: #000;
    color: #fff;
  }






@media screen and (max-width: 1000px) {
    .container {
        margin: 0 30px
    }

    .mobile{
        display: block;
        margin: 0 auto 30px;
    }

    main .container, #dlss4 .container, #reflex2 .container, #ia, #criadores .bg{
        background: none;
        text-align: center;
        padding: 50px 0;
    }

    main{
        text-align: center;
    }

    main .flex{
        justify-content: center;
    }

    main .texto, #dlss4 .texto, #reflex2 .texto, #ia .texto, #criadores .texto{
        max-width: none;
    }

    #criadores .flex{
        translate: 0 0;
        text-align: center;
    }

    
}

