body {
    margin: 0;
}

/* ! Diseño para el layout y contenedor de la imagen */
.container {
    display: flex;
    position: relative;
    width: 100%;
    height: 100vh;
    align-items: center;
    justify-content: center;
}

.layout{
    width: 350px;
    position: relative;
}


/* * Diseño de la estructura general del control */
.entertainment {
    box-sizing: border-box;
    font-family: sans-serif;
    position: absolute;
    margin: 0;
    z-index: 4;
    text-align: center;
    font-style: italic;
    letter-spacing: 3.7px;
    font-size: 6px;
    font-weight: 400;
    transform: scaleY(1.4);
    background-color: #735599;
    color: #d5d4e4;
    margin-left: 80px;
    margin-top: 55px;
    font-weight: 600;
    padding-left: 2px;
}


h1{
    font-family: sans-serif;
    position: absolute;
    margin: 0;
    z-index: 4;
    text-align: center;
    font-style: italic;
    letter-spacing: -2px;
    font-size: 20px;
    font-weight: 400;
    transform: scaleY(1.4);
    color: #735599;
    margin-left: 80px;
    margin-top: 30px;
}


.control{
    box-sizing: border-box;
    position: relative;
    width: 350px;
    height: 200px;
    background-color: #d5d4e4;
    z-index: 1;
    border-radius: 10px;
}   

.circles2 {
    position: absolute;
    width: 220px;
    height: 220px;
    top: 0px;
    left: 220px;
    background-color: #d5d4e4;
    z-index: 2;
    border-radius: 100%;
}

/* ! Siseño de los botones A, B, X, Y */
.botones-circulo {
    box-sizing: border-box;
    position: absolute;
    width: 190px;
    height: 190px;
    top: 15px;
    right: 15px;
    border-radius: 100%;
    border: 1px #a597b1 solid;
    background-color: #a597b1;
}



.botonY {
    box-sizing: border-box;
    position: absolute;
    width: 37px;
    height: 37px;
    top: 75px;
    left: 28px;
    border-radius: 100%;
    background-color: #9e8bdd;
    border: 3px solid #af9fe6;
    z-index: 2;
}

.botonX {
    box-sizing: border-box;
    position: absolute;
    width: 37px;
    height: 37px;
    top: 35px;
    left: 75px;
    border-radius: 100%;
    background-color: #9e8bdd;
    border: 3px solid #af9fe6;
    z-index: 2;
}

.botonB {
    box-sizing: border-box;
    position: absolute;
    width: 37px;
    height: 37px;
    top: 115px;
    left: 75px;
    border-radius: 100%;
    background-color: #5d4083;
    border: 3px solid #8e6fb6;
    z-index: 2;
}

.botonA {
    box-sizing: border-box;
    position: absolute;
    width: 37px;
    height: 37px;
    top: 75px;
    left: 120px;
    border-radius: 100%;
    background-color: #5d4083;
    border: 3px solid #8e6fb6;
    z-index: 2;
}

.fondo-botonesXY {
    position: absolute;
    box-sizing: border-box;
    width: 41px;
    height: 102px;
    background-color: #d5d4e4;
    z-index: 1;
    transform: rotate(50deg);
    left: 49px;
    top: 23px;
    border-radius: 999px;
    border: 2px solid #d5d4e4;
    box-shadow: 
        2px 2px #d5d4e4,
        -2px -2px #d5d4e4,
        -2px 2px #d5d4e4,
        2px -2px #d5d4e4;
}

.fondo-botonesAB {
    position: absolute;
    box-sizing: border-box;
    width: 41px;
    height: 102px;
    background-color: #d5d4e4;
    z-index: 1;
    transform: rotate(50deg);
    right: 52px;
    bottom: 25px;
    border-radius: 999px;
    border: 2px solid #d5d4e4;
    box-shadow: 
        2px 2px #d5d4e4,
        -2px -2px #d5d4e4,
        -2px 2px #d5d4e4,
        2px -2px #d5d4e4;
}

/* ! Botones Start y Select */
.btn-select {
    box-sizing: border-box;
    position: absolute;
    width: 12px;
    height: 40px;
    bottom: 50px;
    left: 130px;
    background-color: rgb(26, 26, 26);
    transform: rotate(45deg);
    border-radius: 30px;
    z-index: 3;
    box-shadow: 
        inset 0px 3px 2px rgb(140, 140, 140),
        inset 0px -3px 2px rgb(140, 140, 140),
        inset -3px 0px 2px rgb(140, 140, 140),
        inset 3px 0px 2px rgb(140, 140, 140);
        
    outline: 1px solid #735599;
    outline-offset: 2px;
}

.btn-start {
    box-sizing: border-box;
    position: absolute;
    width: 12px;
    height: 40px;
    bottom: 50px;
    left: 180px;
    background-color: rgb(26, 26, 26);
    transform: rotate(45deg);
    border-radius: 30px;
    z-index: 3;
    box-shadow: 
        inset 0px 3px 2px rgb(140, 140, 140),
        inset 0px -3px 2px rgb(140, 140, 140),
        inset -3px 0px 2px rgb(140, 140, 140),
        inset 3px 0px 2px rgb(140, 140, 140);
    outline: 1px solid #735599;
    outline-offset: 2px;
}

.text-select {
    position: absolute;
    z-index: 4;
    bottom: 13px;
    left: 110px;
    font-size: 10px;
    font-family: sans-serif;
    letter-spacing: -0.5px;
    font-style: italic;
    transform: scaleX(1.1) scaleY(1.3);
    color: #735599;
}

.text-start {
    position: absolute;
    z-index: 4;
    bottom: 13px;
    left: 170px;
    font-size: 10px;
    font-family: sans-serif;
    letter-spacing: -0.5px;
    font-style: italic;
    transform: scaleX(1.1) scaleY(1.3);
    color: #735599;
}

/* ! Diseño de las arrows */

.circles {
    position: absolute;
    width: 220px;
    height: 220px;
    top: 0px;
    right: 220px;
    background-color: #d5d4e4;
    z-index: 2;
    border-radius: 100%;
}

.flechas {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(3, 1fr);
    box-sizing: border-box;
    position: absolute;
    width: 100px;
    height: 100px;
    left: 55px;
    top: 60px;
    border-radius: 100%;
    outline: 1px #735599 solid;
    outline-offset: 13px;
    z-index: 3;
}

.arrow-center {
    display: flex;
    position: relative;
    width: 100%;
    height: 100%;
    grid-column: 2 / 3;
    grid-row: 2 / 3; 
    background-color: rgb(70, 70, 70);
    align-items: center;
    justify-content: center;
}

.arrow-up {
    position: relative;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    grid-column: 2 / 3; 
    grid-row: 1 / 2; 
    background-color: rgb(70, 70, 70);
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    box-shadow: inset 4px 4px 3px #888;
}

.arrow-down {
    position: relative;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    grid-column: 2 / 3; 
    grid-row: 3 / 4; 
    background-color: rgb(70, 70, 70);
    border-bottom-right-radius: 5px;
    border-bottom-left-radius: 5px;
    box-shadow: inset -4px -4px 3px #222;
}

.arrow-right {
    position: relative;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    grid-column: 3 / 4; 
    grid-row: 2 / 3; 
    background-color: rgb(70, 70, 70);
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
    box-shadow: inset -4px -4px 3px #222;
}

.arrow-left {
    position: relative;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    grid-column: 1 / 2; 
    grid-row: 2 / 3; 
    background-color: rgb(70, 70, 70);
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
    box-shadow: inset 4px 4px 3px #888;
}  


.arrow-center-circle {
    width: 80%;
    height: 80%;
    background-color: #333;
    border-radius: 100%;
}