@charset "utf-8";
.inner:after {
    content: "";
    clear: both;
    display: block;
}
li {
    line-height: inherit;
}
/* header */
.f_w-bold {
    font-family: "ヒラギノ角ゴ ProN W4";
}
.service-header {
    width: 100%;
    background-color: #0e9794;
    z-index: 89;
}
.service-header a, .service-header {
    color: #fff;
    text-decoration: none;
}
.service-header a:hover {
  color: #fff;
}
.service-header .inner {
    position: relative;
}
.service-header .logo {
    float: left;
}
.service-header .button {
    float: right;
}
.service-header .contact_form a {
    background: #fff;
}
.service-header .contact_form a:hover {
    background: #ddd;
    text-decoration: none;
}
.service-header .apply a {
    background: #fa748f;
    color: #fff;
}
.service-header .apply a:hover {
    background: #e46c82;
    text-decoration: none;
}
.service-header .apply a i, .service-header .contact_form a i {
    font-size: 18px;
    line-height: 14px;
}
.service-header .button-inner {
    float: right;
    padding-top: 0px;
}
.service-header .button-inner li {
    display: inline-block;
    margin-right: 20px;
}
.service-header .button-inner li {
    display: inline-block;
    margin-right: 10px;
}
/* Fixed */
.service-header.fixed {
    margin-top: 0;
    top: 0;
    position: fixed;
    height: 50px;
    background: #0e9794;
}
.service-header.fixed .service-nav ul li a {
    color: #333;
    padding: 0 20px;
}
/* Toggle Button */
.service-toggle {
    display: none;
    position: absolute;
    right: 20px;
    top: 14px;
    width: 24px;
    height: 36px;
    cursor: pointer;
    z-index: 90;
    top: 18px;
}

.service-toggle div {
    position: relative;
}

.service-toggle span {
    display: block;
    position: absolute;
    height: 4px;
    width: 100%;
    background: #fff;
    transition: .35s ease-in-out;
}
@media screen and (min-width: 960px) {
    .service-header .service-sub-header {
        height: 50px;
        background: #0e9794;
        width: 960px;
        margin: 0 auto;
    }
    .service-nav ul {
        list-style: none;
        margin: 0 auto;
        width: 960px;
    }
    .service-nav ul li a {
        padding: 0 30px;
    }
    .service-header .logo {
        float: left;
        margin: 10px 0 0 0;
    }
    /* 現サイトのcss */
    #main_navigation {
        background: url(../images/main_navi_bg.png);
        border-top: 1px solid #152635;
        border-top: 1px solid rgba(0, 0, 0, 0.4);
        height: 53px;
    }
    #main_navigation ul.service-nav-inner {
        text-align: center;
        line-height: 0;
    }
    #main_navigation ul.service-nav-inner li {
        display: inline-block;
    }
    #main_navigation ul.service-nav-inner li.stay {
        position: relative;
    }
    #main_navigation ul.service-nav-inner li.stay:after {
        content: '';
        position: absolute;
        left: 50%;
        bottom: 0;
        width: 28px;
        height: 10px;
        margin-left: -14px;
        background: url(../images/main_navi_stay.png) 0 0 no-repeat;
    }
    #main_navigation ul.service-nav-inner li a {
        display: inline-block;
        padding: 18px 35px;
        color: #fff;
        font-size: 17px;
        line-height: 1;
    }
    #main_navigation ul.service-nav-inner li.stay a {
        color: #8794a1;
    }
    .submenu {
        float: right;
        padding-top: 15px;
        padding-right: 5px;
        font-size: 14px;
    }
    .submenu li {
        display: inline-block;
        margin-right: 20px;
    }
    .service-header .contact_form a {
        display: inline-block;
        padding: 7px 20px 9px 20px;
        color: #444;
        line-height: 1;
        font-size: 14px;
        border-radius: 3px;
        margin-top: 9px;
    }
    .service-header .apply a {
        display: inline-block;
        padding: 7px 20px 9px 20px;
        line-height: 1;
        font-size: 14px;
        border-radius: 3px;
    }
    #main_navigation ul.service-nav-inner li.win-vps-menu {
        display: none;
    }
}

@media screen and (max-width: 959px) {
    .f_w-bold {
        position: relative;
    }
    .service-header a:hover {
      text-decoration: none;
    }
    .service-header .apply a i, .service-header .contact_form a i {
        position: absolute;
        top: 35%;
        right: 10%;
    }
    .service-nav-extra .fa {
        margin-right: 5px;
    }
    .service-header .logo {
        padding: 12px 20px 0;
    }
    .service-header .logo img {
        width: 164px;
    }
    #main_navigation {
        background: none;
        height: auto!important;
        z-index: 2;
    }
    #main_navigation ul.service-nav-inner li.win-vps-menu {
        background-color: #007bbc;
    }
    #main_navigation ul.service-nav-inner li.win-vps-menu figure {
        width: 32px;
    }
    #main_navigation ul.service-nav-inner li.win-vps-menu figure img {
        vertical-align: middle;
    }
    #main_navigation ul.service-nav-inner li.win-vps-menu a:hover {
        background-color: #0055a6;
    }
    .open-service .mask {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 1;
        background: #000;
        opacity: 0.5;
    }
    .service-header {
        top: 50px;
        position: absolute!important;
        margin-top: 0;
        z-index: 89;
    }
    /* Fixed reset */
    .service-header.fixed {
        padding-top: 0;
        background: transparent;
    }
    .service-sub-header {
        background: #0e9794;
        width: 100%;
        height: 50px;
        z-index: 999;
        position: relative;
    }
    .service-header.fixed .logo, .service-header .logo {}
    .service-nav {
        position: absolute;
        /* 開いてないときは画面外に配置 */
        top: -541px;
        background: #333;
        width: 100%;
        text-align: center;
        padding: 10px 0;
        transition: .5s ease-in-out;
    }
    .service-nav ul, .service-nav-extra ul {
        list-style: none;
        position: static;
        right: 0;
        bottom: 0;
        font-size: 14px;
    }
    .service-nav ul li {
        background-color: #1aadaa;
    }
    .service-nav ul li a:hover {
        background-color: #189f9c;
    }
    .service-nav ul.service-nav-inner li {
        float: none;
        position: relative;
        text-align: left;
        border-bottom: 1px solid #76cecc;
        font-size: 16px;
    }
    .service-nav ul.service-nav-inner li::after {
        display: block;
        content: "";
        position: absolute;
        top: 24px;
        right: 28px;
        width: 8px;
        height: 8px;
        border-top: solid 2px #fff;
        border-right: solid 2px #fff;
        -webkit-transform: rotate(135deg);
        -ms-transform: rotate(135deg);
        transform: rotate(45deg);
        -webkit-transform-origin: 50% 50% 0;
        -ms-transform-origin: 50% 50% 0;
        transform-origin: 50% 50% 0;
        transition: .2s ease-in-out;
    }
    .service-header .service-nav ul li a, .service-header.fixed .service-nav ul li a {
        width: 100%;
        display: flex;
        color: #fff;
        height: 58px;
        text-align: left;
        padding: 0 20px;
        font-size: 14px;
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        align-items: center;
    }
    .service-toggle::after {
        display: block;
        content: "";
        position: absolute;
        top: 5px;
        right: 3px;
        width: 13px;
        height: 13px;
        margin-top: -10px;
        border-top: solid 4px #fff;
        border-right: solid 4px #fff;
        -webkit-transform: rotate(135deg);
        -ms-transform: rotate(135deg);
        transform: rotate(135deg);
        -webkit-transform-origin: 50% 50% 0;
        -ms-transform-origin: 50% 50% 0;
        transform-origin: 50% 50% 0;
        transition: .2s ease-in-out;
    }
    .open-service .service-toggle::after {
        margin-top: 0;
        -webkit-transform: rotate(315deg);
        -ms-transform: rotate(315deg);
        transform: rotate(315deg);
        transition: .2s ease-in-out;
    }
    .service-toggle {
        display: block;
    }
    /* .service-nav スライドアニメーション */
    .open-service .service-nav {
        -moz-transform: translateY(580px);
        -webkit-transform: translateY(580px);
        transform: translateY(580px);
    }
    .service-header .inner {
        width: 100%;
    }
    /* sp button */
    .sp-button {
        display: block;
    }
    .sp-button ul {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        overflow: hidden;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    .sp-button li {
        box-sizing: border-box;
        width: 50%;
        min-height: 56px;
        line-height: 54px;
        padding: 30px 0;
    }
    .service-header .service-nav ul li .contact_form a, .service-header .service-nav ul li .apply a {
        width: 90%;
        margin: 0 auto;
        height: 50px;
        border-radius: 3px;
        color: #444;
    }
    .service-header .service-nav ul li .apply a {
        color: #fff;
    }
    .service-nav .service-nav-extra {
        display: block;
    }
    .service-nav .service-nav-extra ul {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        overflow: hidden;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    .service-nav .service-nav-extra li {
        box-sizing: border-box;
        width: 50%;
        min-height: 56px;
        border-top: 1px solid #76cecc;
        border-left: 1px solid #76cecc;
    }
    .service-nav .service-nav-extra a {
        display: block;
        text-align: center;
        color: #fff;
    }
    .service-nav .service-nav-extra .close {
        min-height: 56px;
        text-align: center;
        color: #fff;
        background-color: #25918e;
        box-shadow: 0 1px 0 rgba(0, 0, 0, 0.6);
        line-height: 56px;
    }
    .service-nav .service-nav-extra .close:hover {
        background: #279895;
    }
    .service-nav .service-nav-extra .close .fa {
        margin-right: 8px;
        color: #fff;
        font-size: 20px;
    }
    .service-nav .service-nav-extra .close:hover {
        cursor: pointer;
    }
}
.show-mobile {
    display: none;
}
.hide-mobile {
    display: block;
}