@charset "UTF-8";


/*ローディングスピナー*/

.loader,
.loader:after {
    border-radius: 50%;
    width: 2em;
    height: 2em;
}

.loader {
    color: #000;
    margin: 16px auto;
    position: relative;
    text-indent: -9999em;
    border-top: 0.2em solid rgba(214, 214, 214, 0.2);
    border-right: 0.2em solid rgba(214, 214, 214, 0.2);
    border-bottom: 0.2em solid rgba(214, 214, 214, 0.2);
    border-left: 0.2em solid #343a40;
    -webkit-transform: translateZ(0);
    -ms-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-animation: load8 1.1s infinite linear;
    animation: load8 1.1s infinite linear;
}

@-webkit-keyframes load8 {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@keyframes load8 {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}


/*ローディングスピナーここまで*/


html {
    scroll-behavior: smooth;
}

body{background: #fff url(../img/bg.jpg) center /cover repeat-y fixed;}

ul,
ol {
    list-style: none;
}

.required::after {
    content: '*';
    color: red;
    vertical-align: super;
}

.navbar-dark .navbar-toggler {
    border: none;
}

.navbar-brand > img {
    width: 180px;
    margin-top: -20px;
}

button:focus {
    outline: 0px dotted;
    outline: 0px auto -webkit-focus-ring-color;
}

main:not(#home) {
    padding-top: 65px;
}

section > h2:first-of-type {
    margin-bottom: 30px;
}

section > h2:first-of-type span {
    font-size: 1.2rem;
    border-top: 2px solid #47bfe9;
    width: 100%;
    display: block;
    margin-top: 0.5rem;
    line-height: 2.5rem;
    font-weight: 100;
    color: #f81397;
    text-transform: uppercase;
}

ol.terms_sublist {
    counter-reset: number 0;

}

.terms_sublist li {
    margin-left: -1.5rem;
    line-height: 2rem;
}

.terms_sublist li::before {
    counter-increment: number 1;
    content: "（"counter(number) "）";
    margin-right: -0.5rem;
}

#head_img img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

#head_img + div {
    position: absolute;
    z-index: 1000;
    left: 0;
    right: 0;
    top: 57px;
    color: #fff;
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
    height: 512px;
}

#head_img+div>h1,
    #head_img+div>h2{
        font-size: 1.5rem;
    }

#head_img::after {
    content: '';
    display: inherit;
    background: rgba(0, 0, 0, 0.71);
    position: absolute;
    height: 512px;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1;
}

#backToTop a {
    color: #999;
    text-decoration: none;
}

#backToTop a:hover {
    text-decoration: none;
    color: cadetblue;
}

.navbar-brand {}

.navbar {
    padding: 0.5rem 0 0;
}

ul.navbar-nav {
    text-align: right;
    background: #455850;
}

ul.navbar-nav.mr-auto li {
    padding: 0 1rem;
    border-bottom: 1px solid #b5b5b5
}

ul.navbar-nav.mr-auto li:nth-child(odd) {
    /*background: #535353;*/
}

.bg-green {
    background: #1f1f1f;
}

.bg-darkgray {
    background: #1a1a1a;
}

.about_tl h2 {
    font-size: 1.3rem;
}

.about_tl img {
    width: 100%;
}

.back_img01 {
    background: #fff url(../img/01.jpg) center/150% no-repeat;
}

.back_img02 {
    background: #fff url(../img/02.jpg) center/cover no-repeat;
}

.back_img03 {
    background: #fff url(../img/03.jpg) center/cover no-repeat;
}

.back_img04 {
    background: #fff url(../img/04.jpg) center/cover no-repeat;
}

div[class*="back_img"] {
    border: 4px solid #fff;
}

div[class*="back_img"] div {
    background: rgba(81, 46, 230, 0.54);
    border: 1px solid #ac9af5;
}

div[class*="back_img"] h4 {
    color: #ffffff
}

#growup h4{
    background: #10bf90;
    color: #fff;
    font-weight: bold;
}
#price_list .select_btn{
width: 80%;
    margin: 0 auto;
}
#price_list .select_btn>input[type=checkbox] {
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
  border: 0;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
}

#price_list .select_btn>input+label{
    background: #507db1;
    padding: 10px 8px;
    color: #fff;
    border-radius: 5px;
    display: block;
    text-align: center;
}

#price_list .select_btn>input+label:hover{
    cursor: pointer;
    background: #2d7ad3;
}

#price_list .select_btn>input:checked+label{
    background: #075dbf;
}

/*#price_list thead {
    display: none;
}

#price_list .table-bordered {
    border: none;
}

#price_list tbody tr:nth-of-type(even) {
    background: #baecf4
}

#price_list tbody tr {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 30px;
    border: 1px solid #ccc;
}

#price_list tbody td p {
    margin: 0;
}

#price_list tbody td:nth-of-type(1) {
    width: 30%;
    border: none;
}

#price_list tbody td:nth-of-type(2) {
    width: 100%;
    border: none;
    border-top: 1px solid #ccc;
}

#price_list tbody th {
    width: 70%;
    border: none;
    border-right: 1px solid #ccc;
}*/

#total_price{
    text-align: center;
    font-size: 1.5rem;
}

.total_price{
   display: table-cell;
  vertical-align: middle;
}

.total_price>input{
   
}


.total_price::before {
    content: '￥';
    background-color: #dee2e6;
    color: #000;
    position: absolute;
    z-index: 1000;
    line-height: 4.7rem;
    font-size: 1.7rem;
}

* 
{
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
input, button 
{
  margin: 0;
  vertical-align: baseline;
  font: inherit;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: 0;
  outline: 0;
    font-size: 2.3rem;
    
}
input 
{
  line-height: normal;
}
input:focus 
{
  outline: none;
}
input::-webkit-search-decoration, 
input::-webkit-search-cancel-button, 
input::-ms-clear,
input::-ms-reveal 
{
  display: none;
}
input::-moz-focus-inner 
{
  padding: 0;
  border: 0;
}
button 
{
  text-transform: none;
  overflow: visible;
  cursor: pointer;
}
button::-moz-focus-inner 
{
  padding: 0;
  border: 0;
}

.fluid-input 
{
  display: table;
  width: 98%;
    margin: 0 auto;
}
.fluid-input > * 
{
  display: table-cell;
  vertical-align: middle;
}
.label, .button 
{
  width: 1%;
  white-space: nowrap;
}
.label, .box, .button > button 
{
  padding: 0.3em 0.7em;
  line-height: 1.5;
}
.label 
{
  color: #fff;
  background-color: #be0f1c;
}
.box 
{
  width: 100%;
  background-color: #dee2e6;
}





#privacy h3,
#terms h3 {
    font-size: 1.5rem;
    margin-bottom: 30px;
    border: 4px double #1dc3d1;
    padding: 5px;
    border-radius: 5px
}

#privacy > div > ul > li,
#terms > div > ul > li {
    margin-bottom: 30px;
    text-indent: -1rem;
    padding-left: 1rem;
}

#privacy ol li {
    margin-bottom: 0.5rem;
    list-style-type: disc;
}

#terms ol li {
    list-style: decimal;
    margin-bottom: 0.5rem
}

#terms dt {
    background: rgb(94, 135, 152);
    color: #fff;
    padding: 5px 8px;
}

#sctl dl {
    margin-bottom: 30px
}

#sctl dt {
    background-color: #2190be;
    padding: 3px 6px;
    color: #fff;
    border-radius: 2px;
}

#mail_confirm_modal {
    background: rgba(0, 0, 0, 0.81);
    padding: 20px 10%;
    width: 100vw;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    position: fixed;
    z-index: 2000;
    display: none;
}

.mail_confirm_modal_wrap {
    position: relative;
    top: 10%;
    overflow-y: scroll;
    overflow-x: hidden;
    height: 80%;
}

#option_menu .card-body li>div{
    border: 2px solid #000;
    padding: 25px 20px;
    border-radius: 8px;
    font-weight: bold;
    text-align: center;
    box-sizing: border-box;
    background: rgba(255, 255, 255, 0.81);
}

#option_menu .card-body li:nth-of-type(1) div{
    border-color: #87e07f;
    color: #2ec720;
}

#option_menu .card-body li:nth-of-type(2) div{
    border-color: #d9c65e;
    color: #e8ae11;
}

#option_menu .card-body li:nth-of-type(3) div{
    border-color: #FFA594;
    color: #ff6a4d;
}

#option_menu .card-body li:nth-of-type(4) div{
    border-color: #7fbbe0;
    color: #108ac1;
}

#option_menu .card-body li p{
    margin: 0;
}

.python{
background: url(/img/python.svg) center/50px no-repeat;
}

.java{
background: url(/img/java.svg) center/50px no-repeat;
}

.system{
background: url(/img/system.svg) center/50px no-repeat;
}

.linux{
background: url(/img/linux.svg) center/50px no-repeat;
}

#brand-logo
    {
   padding-top: .5rem
    }

#affiliate_bunner{
    background: url(/img/affiliate_bg.jpg) center/cover no-repeat rgb(255, 255, 255);
}

#affiliate_bunner p{
    word-break: keep-all;
    overflow-wrap: break-word;
}
@media (min-width: 768px) {

    .navbar-expand-md .navbar-collapse {
        justify-content: flex-end;
        text-align: right
    }
    
    #head_img+div>h1,
    #head_img+div>h2{
        font-size: 2.5rem;
    }
    
    .fluid-input {
        width: 50%;
    }
    
    #brand-logo
    {
    margin-top: -.5rem
    }
    

}



@media (min-width: 992px) {
    main:not(#home) {
        padding-top: initial;
    }

    .navbar {
        padding: 0.5rem 1rem;
    }

    .navbar-brand > img {
        margin-top: 0px;
    }

    section > h2:first-of-type {
        margin-bottom: 80px;
    }

    ul.navbar-nav {
        position: absolute;
        left: calc(50% - (456px / 2));
        background: initial;

    }

    ul.navbar-nav li:hover {
        text-decoration: underline !important;
        text-decoration-color: #7fbc92 !important;
        text-underline-offset: 8px !important;



    }

    ul.navbar-nav.mr-auto li {
        font-size: 0.9rem;
        padding: initial;
        border-bottom: initial;
    }

    ul.navbar-nav.mr-auto li:nth-child(odd) {
        background: initial;
    }

    #price_list .table-bordered {
        border: 1px solid #ccc;
    }

    #price_list thead {
        display: inherit;
    }

    #price_list thead th:nth-of-type(1) {
        min-width: 233px;
    }

    form[name='purchaseform'] #price_list thead th:nth-of-type(1) {
        min-width: 260px;
    }

    #price_list tbody th {
        min-width: 233px;
        width: inherit;
    }

    form[name='purchaseform'] #price_list tbody th:nth-of-type(1) {
        min-width: 260px;
    }

    #price_list tbody tr {
        display: inherit;
        margin-bottom: 0px;
        border-top: 1px solid #ccc;
    }

    #price_list thead th:nth-of-type(2) {
        min-width: 110px;
    }

    #price_list thead th:nth-of-type(3) {
        width: 100%;
    }

    #price_list tbody td:nth-of-type(1) {
        width: initial;
        border-top: 1px solid #ccc;
        border-right: 1px solid #ccc;
        min-width: 110px;
    }

    #price_list tbody td:nth-of-type(2) {
        width: initial;
        border-top: 1px solid #ccc;
    }




}
