/* REGISTRATION */

.register-box{
  width:950px;
  height:500px;
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  margin:auto;
  margin-top:2rem;
  max-width:950px; /* no mobile support for this yet */
}

.register-box #screen1,
.register-box #screen2,
.register-box #screen3,
.register-box #screen4{
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:100%;
}

.register-box .element{
  position:absolute;
}

.register-box #volume{
  background-image:url(../assets/volume/volume0001.svg);
  width:35px;
  height:34px;
  bottom:1rem;
  right:1rem;
  border-radius:50%;
  cursor:pointer;
  z-index:1;
}

.register-box #volume:hover{
  scale:1.05;
  filter:brightness(1.05);
}

.register-box #volume:active{
  scale:0.95;
}

.register-box #volume[data-state="off"]{
  background-image: url(../assets/volume/volume0002.svg);
}

#screen1{
  display:flex;
  justify-content:space-evenly;
  align-items:center;
}

.player-selection-board .arrow{
  position:absolute;
  left:0;
  right:0;
  top:0;
  bottom:0;
  width:50px;
  height:50px;
  align-self:center;
  justify-self:center;
  pointer-events:none;
}

.player-selection-board .arrow.girl[data-angle="1"]{ background-image:url(../assets/screen1/arrow/arrowGirl0001.svg); }
.player-selection-board .arrow.girl[data-angle="2"]{ background-image:url(../assets/screen1/arrow/arrowGirl0002.svg); }
.player-selection-board .arrow.girl[data-angle="3"]{ background-image:url(../assets/screen1/arrow/arrowGirl0003.svg); }
.player-selection-board .arrow.girl[data-angle="4"]{ background-image:url(../assets/screen1/arrow/arrowGirl0004.svg); }

.player-selection-board .arrow.boy[data-angle="1"]{ background-image:url(../assets/screen1/arrow/arrowBoy0001.svg); }
.player-selection-board .arrow.boy[data-angle="2"]{ background-image:url(../assets/screen1/arrow/arrowBoy0002.svg); }
.player-selection-board .arrow.boy[data-angle="3"]{ background-image:url(../assets/screen1/arrow/arrowBoy0003.svg); }
.player-selection-board .arrow.boy[data-angle="4"]{ background-image:url(../assets/screen1/arrow/arrowBoy0004.svg); }

.player-selection-board{
  /*position:absolute;
  top:5rem;
  bottom:0;
  left:2rem;*/
  position:relative;
  width:220px;
  height:350px;
  background-image:url(../assets/screen1/player_selection_board.svg);
  display:flex;
  flex-direction:column;
  align-items:center;
}

.player-selection-board .title{
  width:233px;
  height:42px;
  position:relative;
  top:0rem;
  text-align:center;
}

.player-selection-board.female .title{ background-image:url(../assets/screen1/player_selection_title_female.svg); }
.player-selection-board.male .title{ background-image:url(../assets/screen1/player_selection_title_male.svg); }

.player-selection-board .title h2{
  transform:translateY(7px);
  font-family:"HirukoWeb", sans-serif;
  font-weight:normal;
  color:white;
  font-size:21px;
  user-select:none;
}

.player-selection-board .content{
  display:flex;
  flex-wrap:wrap;
  width:inherit;
  height:275px;
  padding:10px 15px;
  gap:10px;
}

.player-selection-board .content .character-box{
  flex:0 0 47%;
  background-color:#F7BE63;
  height:120px;
  border-radius:10px;
  box-shadow:4px 4px 0 #A86F24;
  cursor:pointer;
}

.player-selection-board .content .character-box:hover,
.player-selection-board .content .character-box[data-selected="true"]{
  background-color:#98C93C;
}

.player-selection-board .content .character-box img{
  width:100%;
  height:100%;
  object-fit:contain;
  transform:translateY(-7px);
  pointer-events:none;
  user-select:none;
}

.player-selection-preview{
  user-select:none;
  pointer-events:none;
}

.register-box > .banner{
  position:relative;
  background-image:url(../assets/banner.svg);
  width:755px;
  height:105px;
  margin:auto;
  text-align:center;
  flex-shrink:0;
  font-family:"HirukoWeb", sans-serif;
  color:#0295E1;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:7px;
  margin-bottom:30px;
  user-select:none;
}

.register-box > .banner > h1{ font-size:25px; font-weight:normal; }
.register-box > .banner > p{ font-size:20px; }

.register-box > .screen-holder{
  position:relative;
  height:100%;
  width:100%;
}

.register-box .stages{
  background-image:url(../assets/stage.svg);
  width:270px;
  height:63px;
  display:flex;
  justify-content:space-evenly;
  align-items:center;
  gap:32px;
  font-family:"HirukoWeb", sans-serif;
  color:#0295E1;
  font-size:25px;
  user-select:none;
  position:relative;
}

.register-box .stages .stage[data-active="true"]{
  color:white;
}

.register-box .stages .stage[data-active="true"]::before{
  content:"";
  position:absolute;
  width:46px;
  height:48px;
  left:-15px;
  top:-9px;
  background-color:#0295E1;
  display:inline-block;
  border-radius:50%;
}

.register-box .stages .stage{
  position:relative;
}

.register-box .stages .stage > span{
  z-index:1;
  position:relative;
}

.register-box .navigation{
  bottom:0;
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center;
  position:relative;
  transform:translateY(1rem);
}

.register-box .navigation .button{
  font-family:"HirukoWeb", sans-serif;
  font-size:20px;
  font-weight:normal;
  padding:10px;
  display:block;
  margin:0 10px;
  border:none;
  background:none;
  background-image:url(../assets/button/button0001.svg);
  width:150px;
  height:63px;
  color:white;
  text-shadow:0 2px #2075C9;
  cursor:pointer;
}

.register-box .navigation .button[disabled]{
  filter:grayscale(1);
  cursor:default;
}

.register-box .navigation .button > span{
  padding-top:2px;
  display:inline-block;
  pointer-events:none;
}

.register-box .navigation .button:not([disabled]):hover{
  background-image:url(../assets/button/button0002.svg);
}

.register-box .navigation .button:not([disabled]):hover > span{
  padding-top:8px;
  margin-left:-4px;
}

#screen2 .username-board,
#screen3 .password-board{
  width:480px;
  height:340px;
  background-image:url(../assets/screen2/board.svg);
  left:80px;
  top:-30px;
}

#screen2 .username-board .text,
#screen3 .password-board .text{
  margin-top:80px;
  margin-left:40px;
  margin-right:50px;
  display:flex;
  flex-direction:column;
  height:135px;
  position:relative;
  user-select:none;
}

#screen2 .username-board .text h2,
#screen3 .password-board .text h2,
#screen4 .email-board .text h2,
#screen5 .success-board .text h2{
  font-family:"HirukoWeb", sans-serif;
  color:#0295E1;
  font-weight:normal;
  font-size:20px;
}

#screen2 .username-board .text p,
#screen3 .password-board .text p{
  font-family:"Verdana", sans-serif;
  font-size:14px;
  color:#7f5414;
}

#screen2 .form-validation,
#screen3 .form-validation,
#screen4 .form-validation{
  position:relative;
  width:max-content;
}

#screen2 .form-validation input,
#screen3 .form-validation input{
  width:360px;
  height:35px;
    border:none;
  border-radius:5px;
  box-shadow:0 0 6px rgb(24 24 24 / 71%);
}

#screen2 .my-player-preview,
#screen3 .my-player-preview,
#screen4 .my-player-preview,
#screen5 .my-player-preview{
  right: 155px;
  width: 180px;
  top: -35px;
}

.screen-holder .my-player-preview > img{
  width:100%;
  height:auto;
}

.form-input{
  font-family: "HirukoWeb";
  font-weight: normal;
  font-size: 20px;
  color:rgb(24 24 24);
  padding:0 10px;
}

.form-validation.status:after{
  content: "";
  width: 34px;
  height: 34px;
  right:1px;
  top:0;
  bottom:0;
  position: absolute;
  border-radius: 50%;
  display:inline-block;
}

.form-validation.status.loading:after{ background-image:url(../assets/validator/status0001.svg); }
.form-validation.status.valid:after{ background-image:url(../assets/validator/status0002.svg); }
.form-validation.status.invalid:after{ background-image:url(../assets/validator/status0003.svg); }

.grow{
  flex-grow:1;
}

.screen-holder p[data-type="playerNamePreview"]{
  text-align:center;
  font-weight:normal;
  color:white;
  font-size:18px;
  font-family:"HirukoWeb", sans-serif;
  user-select:none;
}

@supports (-webkit-text-stroke: 1px #fff) and (paint-order: stroke fill){
  .screen-holder p[data-type="playerNamePreview"]{
    -webkit-text-stroke:3px #fff;
    paint-order:stroke fill;
    color:black;
  }
}

.screen-holder .name-holder{
  transform:translateX(8px);
}

#screen4 .checkboxes{
  display:flex;
  flex-direction:column;
}

#screen4 .email-board{
  width:480px;
  height:338px;
  background-image:url(../assets/screen4/email-board.svg);
  left:85px;
  top:-30px;
}

#screen4 .email-board .text{
  position:absolute;
  top:50px;
  left:65px;
  width:360px;
}

#screen4 .email-board .form-input{
  width:100%;
  padding:5px 10px;
  border-radius:8px;
  border:2px solid #bdb8a7;
}

#screen4 .email-board #validatorHolder3{
  padding-bottom:20px;
}

#screen4 .email-board .small-text{
  font-size:11px;
  padding-top:3px;
  padding-left:6px;
  color:#666;
  accent-color:#9FD832;
}

#screen4 .email-board .small-text a{
  font-weight:bold;
  color:black;
}

@keyframes attract{
  90%{
    transform:scale(1);
  }
  95%{
    transform:scale(1.05);
    filter:brightness(1.05);
  }
}

#screen4 .btn.register{
  position:absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  display: block;
  font-size: 19px;
  font-family: "HirukoWeb";
  color: white;
  font-weight: 200;
  width: 235px;
  height: 75px;
  background-image:url(../../css/responsive/assets/welcome/btn0001.svg);
  background-size:cover;
  background-color:transparent;
  border-style:none;
  cursor:pointer;
  animation:attract 6s infinite linear;
}

#screen4 .btn.register:not([disabled]):hover{
  background-image:url(../../css/responsive/assets/welcome/btn0002.svg);
}

#screen4 .btn.register[disabled]{
  filter:grayscale(1) contrast(.5) brightness(1.3);
  cursor:default;
  animation:none;
}

#screen4 .btn.register #registerTxt{
  display:inline-block;
  transform: translateX(5px) translateY(1px);
}

#screen4 .btn.register:not([disabled]):hover #registerTxt{
  transform:translateX(5px) translateY(5px);
}

/* SUCCESS !!!! */

#screen5 .success-board{
  background-image:url(../assets/success/success_board.svg);
  width:515px;
  height:360px;
  left:90px;
  top:-20px;
}

#screen5 .success-board .text p,
#screen5 .success-board .hint p{
  font-family:"Verdana", sans-serif;
  font-size:14px;
  color:#666;
}

#screen5 .success-board .text #successBody{
  font-weight:bold;
}

#screen5 .success-board .text{
  margin-top:65px;
  margin-left:40px;
  margin-right:40px;
}

#screen5 .success-board .text #successBody{
  margin-top:12px;
  margin-right:100px;
}

#screen5 .success-board .text #successSign{
  margin-top:8px;
}

#screen5 .success-board .holder{
  position:relative;
}

#screen5 .success-board .hint{
  position:absolute;
  top:150px;
  left:75px;
  width:375px;
}

#screen1 h2,
#screen2 h2,
#screen3 h2,
#screen4 h2,
#screen5 h2{
  user-select:none;
}

.error{
  display:block;
  margin-top:1ch;
  color:#f00!important;
  position:absolute;
  background-color:white;
  padding:1ch;
  border:2px solid #f00;
  border-radius:8px;
  z-index:1;
  font-size:11px;
  user-select:none;
  /*pointer-events:none;*/
}