/* set */
.container {width: 1450px; margin: 0 auto;}
#wrap {width: 100%; overflow-x: hidden;}
#wrap_content {position: relative; width: 100%; min-height: 100vh; overflow: hidden;}
.login:before{content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 90%; height: 90%;}
.cafe {font-family: 'Cafe24ClassicType-Regular';}
section {}
input:focus {box-shadow: 0 0 5px rgba(255,255,255,0.3);}


/* ========================= login ========================= */
/* 로그인 */
#wrap_content.login {background: url('/assets/img/xo/bg/login_bg.jpg') no-repeat center/cover;}
#wrap_content .login_bg_sub{position: absolute; bottom: 0; left: 0; max-width: 568px;}
.login_section{
    width: 100%; max-width: 527px;
    position: absolute; padding: 22px 40px 93px 40px; top: 15%; right: 20%; z-index: 1; background: rgba(0, 0, 0, 0.53); border: 3px solid #FFEFAD;
}
.login_logo {position: relative; width: 264px; margin: auto;}
.login_wrap {position: relative; width: 100%;}

.login_box {margin-top: 52px; display: flex; align-items: center; flex-direction: column;}
.login_box_input{ display: flex; flex-direction: column; gap:20px; width: 100%; max-width: 297px;}
.login_input_wrap{display: flex; flex-direction: column; gap:6px;}
.row {position: relative; _width: 280px;}
.login_input {display: flex; align-items: center; height: 50px; padding: 12px;
    border: 1px solid #FFE4B5; background: #fff; width: 100%; max-width: 297px;}
.login_input:first-child {margin-bottom: 20px;}
.login_input label {display: block; width: 50px; font-size: 13px; padding-left: 20px; color: #B8B8B8;}
.login_input input {width: calc(100% - 58px); font-size: 14px; color: black;}
.login_input input:focus {box-shadow: none;}

.login_info {display: flex; align-items: center; justify-content: center; gap: 5px; margin: 15px 0 30px;}
.login_info img {width: 20px;}
.login_info span {display: block; font-size: 13px;}

.login_btn {width: 100%; max-width: 297px; height: 50px; background: #FFEFAD; font-size: 15px; font-weight: 500;}
.login_box .btn_box {display: flex; align-items: center; justify-content: center; gap: 25px; margin-top: 24px;}
.login_box .btn_box li {position: relative; font-size: 16px; color: #CBCBCB;}
.login_box .btn_box li::after {content: ''; position: absolute; top: 50%; right: -14px; display: block;
    width: 4px; height: 4px; border-radius: 50px; background: #CBCBCB; transform: translateY(-50%);}
.login_box .btn_box li:last-child::after {display: none;}
.login_box .btn_box li:hover a {text-shadow: 0 0 5px rgba(255,255,255,0.5);}

/* ========================= index ========================= */
/* main banner */
#wrap_content.main {background: url('/assets/img/xo/bg/main_bg.jpg') no-repeat top center/100% auto;}
.main_banner {width: 100%; _margin-top: -50px;}
.main_banner_swiper {width: 800px; margin: 0 auto; padding-top: 100px}
.slide_banner {width: 100%;}
.slide_banner p {font-size: 24px;  text-shadow: 0px 0px 8px #000000; font-weight: 500;
    color: #F9E9AC; text-align: center; margin-bottom: 10px;}
.slide_banner p span {font-size: 24px; color: #FFC914; font-weight: 500;}
.detail_btn {width: 154px; height: 38px; font-size: 14px;}
.gr_btn {display: block; background: #200303; border: 1px solid #C58F20; color: #FFEFAD; text-align: center;
    box-shadow: 0px 4px 5px rgba(0, 0, 0, 0.5); border-radius: 30px; margin: 0 auto;}
.main_banner_swiper .swiper-pagination {bottom: 0;}
.main_banner .main_banner_swiper .swiper-pagination-bullet {width: 8px; height: 8px; background: #fff; margin: 0 7px;}

/* game list */
.game_banner {position: relative; width: 100%; margin: 250px auto 0;}

.game_wrap {position: relative; z-index: 1;}
.game_wrap .tab_box {margin: 0 auto; position: relative; display: flex; align-items: center; justify-content: center; gap: 46px; }
.game_wrap .tab_box .tab_box_logo{z-index: 1; max-width: 323px; position: absolute; top: -40%; left: 50%; transform: translateX(-50%);}
.game_wrap .tab_box .tab_box_bg_sub{position: absolute; height: 100%; right: 0; bottom: 0;}
.game_wrap .tab_box .tab_box_wrap{width: 100%; position: relative; overflow: hidden; display: flex;
    border-radius: 45px;border: 2px solid #FFDF83;
    background: url('/assets/img/xo/bg/tab_box_bg.jpg') no-repeat center/cover;
    gap: 46px; padding: 85px 0 85px 5%;}
.tab_btn {position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; width: 250px; height: 250px;
    cursor: pointer; _box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25); _background: rgba(0, 0, 0, 0.15); transition: 0.3s; overflow: hidden;}
.tab_btn img{width: 93%;}
.tab_btn::after {content: ''; display: block; position: absolute; top: 0; left: 0; width: 0; height: 100%; transition: 0.6s; z-index: -1;}
/*.tab_btn:hover::after {width: 150%; background: linear-gradient(90deg, #000000 0%, rgba(0, 0, 0, 0.810012) 84.84%, rgba(0, 0, 0, 0) 100%);}*/
.tab_btn.active {_background: #000000;}


.tab_btn:hover {animation: pulse 1s infinite;}
.tab_area {display: none; margin-top: 60px; min-height: 780px;}
.tab_area.active {display: block;}
.card_list {display: flex; align-items: flex-start; flex-wrap: wrap; gap: 21px;}
.card_box {position: relative; width: 224px; height: 334px; background: url('/assets/img/xo/source/card_img.png') no-repeat center/contain;
    padding: 15px 10px; cursor: pointer; transition: 0.4s;}
.card_box::after {content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: 17px;
    background: linear-gradient(100deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.3058823529),
    rgba(255, 255, 255, 0.4196078431), rgba(0, 0, 0, 0.3058823529), rgba(0, 0, 0, 0), rgba(0, 0, 0, 0));
    background-size: 1000% 100%; animation: gradient 4s infinite;
}
.card_box:hover {scale: 1.2; z-index: 10; filter: drop-shadow(4px 4px 20px rgba(242, 210, 4, 0.766));
    transform: translateY(-10px) rotate(10deg); }
.card_box .start {opacity: 0; position: absolute; z-index: 1; width: 40px; right: -14px; top: -18px;
    scale: 1; animation: starticon 4s infinite;
}
.card_character {position: absolute; top: 100px; left: 50%; width: 155px; height: 155px; transform: translateX(-50%); border-radius: 50%; object-fit: cover;}
.game_logo {position: absolute; bottom: 40px; left: 50%; width: 88px; height: 36px; object-fit: contain; transform: translateX(-50%);}
.card_box .name {font-size: 20px; color: #fff;   -webkit-text-stroke: 1px #FFBF3E; text-align: center; font-weight: 500; margin: 33px 0 0;}

@keyframes gradient {
    0% {
      background-position: 100%;
    }
    100% {
      background-position: 0%;
    }
}
@keyframes starticon {
    0% {
      transform: rotate(0deg);
      opacity: 0;
    }
    35% {
      transform: rotate(0deg);
      opacity: 0;
    }
    50% {
      opacity: 1;
      transform: rotate(100deg);
      scale: 1.5;
    }
    75% {
      transform: rotate(0deg);
      opacity: 0;
    }
    100% {
      transform: rotate(0deg);
      opacity: 0;
    }
}

/* bank */
.bank_section {width: 100%; margin-top: 100px;}
.bank_box {display: flex; align-items: flex-start; gap: 20px;}
.bank_inner {border: 1px solid #E2CDBA; background:#1E1708; width: 100%;}
.return_box {width: 570px;}

.bank_title {display: flex; align-items: center; justify-content: space-between;
    width: 100%; height: 80px; padding: 0 24px;}
.bank_title p {color: #C1AD8B;}
.bank_title a {font-size: 12px; color: #999;}
.bank_title span {font-size: 24px; color: #C1AD8B;}

.bank_list li:nth-child(odd) {background: rgb(0 0 0 / 24%);}
.bank_list li b {color: #C1AD8B; font-weight: 400;}
.bank_list li {display: flex; align-items: center; width: 100%; height: 42px; padding: 0 12px 0 24px;}
.bank_list li * {font-size: 14px;}
.bank_list li span {display: block; width: 128px; text-align: right;}
.bank_list li p {width: calc(100% - 300px);}
.bank_list li b {width: 150px; text-align: right; margin-right: 20px;}
.bank_list li span {display: block; width: 130px; text-align: right;}
.return_box li p {width: calc(100% - 85px);}
.bank_menu_list {display: flex; align-items: center; background: rgba(91,88,88,.25);
    height: 80px; margin-top: 34px;}
.bank_menu_box {display: flex; align-items: center; justify-content: center; width: 440px;
    border-right: 1px solid rgba(255,255,255,0.1); cursor: pointer;}
.bank_menu_box p {font-size: 20px; color: #B1722A;}
.bank_menu_box p:hover {text-shadow: 0 0 5px rgba(255,255,255,.3);}
.bank_menu_box img {width: 44px; margin-right: 12px;}
.bank_menu_box span {display: block; font-size: 12px; color: #fff; font-weight: 100; margin-top: 8px;}
.bank_submenu_box {display: flex; align-items: center; width: calc(100% - 880px);}
.submenu_box {display: flex; align-items: center; justify-content: center; width: 50%;}
.submenu_box img {width: 32px; margin-right: 12px;}
.submenu_box p {font-size: 16px; color: #B1722A; cursor: pointer;}
.submenu_box p:hover {text-shadow: 0 0 5px rgba(255,255,255,.3);}