/* 共通部分 */
body {
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
    font-weight: 500;
    background:url(../img/background_img.jpg);
}
img {
    width: 100%;
    border-radius: 4px;
}
a {
    color: #000;
    cursor: pointer;
}
.inner {
    max-width: 1200px;
    margin: 0 auto 64px;
}
section {
    margin-bottom: 64px;
}
h3 {
    display: inline-block;
}
.section_title {
    font-size: 32px;
    text-align: center;
    line-height: 1.0;
    margin-bottom: 64px;
    font-weight: 700;
}
.section_title h3 {
    position: relative;
}
.section_title h3::after {
    content: "";
    position: absolute;
    border-bottom: 4px solid #B31312;
    top: 130%;
    left: 0%;
    width: 100%;
    height: auto;
}
main {
    width: 100%;
}



/* header部分 */
.header_top {
    display: flex;
    justify-content: space-between;
    width: 100%;
    height: 60px;
    padding: 16px;
    align-items: center;
    border-bottom: 3px solid #B31312;
    position: fixed;
    z-index: 2;
    background-color: #F8F6F4;
}
.header_fixed {
    position: fixed;
}
.header_top_title {
    font-size: 20px;
    font-weight: 700;

}
.header_top_contact {
    display: flex;
    align-items: center;
    height: 60px;
}
.header_top_tel {
    font-size: 20px;
    font-weight: 700;
    margin-right: 8px;
}
.header_top_inst a img {
    width: 30px;
    height: 30px;
}
/* header_main部分 */
.header_main {
    display: flex;
    text-align: center;
    max-width: 1800px;
}
.header_main_inner {
    display: flex;
    margin: 120px auto;
    align-items: center;
}
.header_list {
    max-width: 400px;
}
.header_items {
    font-weight: 700;
    font-size: 18px;
    margin-bottom: 24px;
}
.header_items:nth-child(3) {
    margin-bottom: 0;
}
.header_items_font_small {
    font-size: 14px;
}
.header_main_logo {
    margin: 0 32px;
}
.header_main_logo img {
    width: 320px;
    height: 320px;
}
#g-nav ul {
    display: none;
}
.header_sp_list {
    display: block;
    width: 880px;
    height: 100px;
}
.header_sp_items {
    width: 100%;
    height: auto;
}
/* fv部分 */



/* manager部分 */
.manager_inner {
    max-width: 720px;
    margin: 0 auto 120px;
}
.manager_img {
    max-width: 750px;
    height: auto;
    margin-bottom: 32px;
    padding: 0 16px;
}
.manager_img img {
    width: 100%;
}
.manager_text {
    width: 80%;
    line-height: 2.2;
    text-align: justify;
    font-size: 18px;
    background-color: #ffffff;
    margin: 0 auto;
    padding: 16px 24px;
}
/* shop_point部分 */
.shop_point_box {
    display: flex;
    justify-content: space-between;
    max-width: 1200px;
    margin: 64px auto 112px;
}
.shop_point_box_img {
    width: 50%;
}
.shop_point_box_text {
    display: flex;
    align-items: center;
    text-align: justify;
    width: 44%;
    height: auto;
    font-size: 18px;
    line-height: 2.5;
}
/* chicken_wings部分 */
.chicken_wings_part {
    max-width: 720px;
    margin: 0 auto;
}
.chicken_wings_content {
    max-width: 420px;
    margin: 64px auto 80px;
    font-size: 18px;
    line-height: 2.5;
    text-align: justify;
}
.chicken_wings_make {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.chicken_wings_make_text {
    max-width: 240px;
    text-align: center;
    margin: 16px auto 64px;
}
.chicken_wings_make_img img {
    width: 280px;
    height: 200px;
}
/* menu.course部分 */
.menu_content {
    display: flex;
    justify-content: space-between;
    margin-bottom: 72px;
}
.menu_rice_noodle {
    justify-content: center;
}
.menu_text {
    width: 38%;
    border-radius: 4px;
    background-color: #ffffff;
    padding: 16px;
    font-size: 18px;
}
.menu_text_rank {
    width: 100%;
    text-align: center;
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 30px;
}
.menu_text_box {
    display: flex;
    justify-content: space-between;
    margin-bottom: 32px;
}
.menu_btn_box {
    max-width: 400px;
    margin: 0 auto 32px;
    text-align: center;
    position: relative;

}
.menu_price p {
    color: #B31312;
    text-align: right;
}
.menu_btn a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 auto;
    padding: 1em 2em;
    width: 320px;
    color: #B31312;
    font-size: 18px;
    font-weight: 700;
    border: 3px solid #B31312;
    border-radius: 10px;
}
.menu_btn a::after {
    content: '';
    width: 8px;
    height: 8px;
    border-top: 3px solid #B31312;
    border-right: 3px solid #B31312;
    transform: rotate(45deg);
}
.menu_btn a:hover {
    color: #ffffff;
    text-decoration: none;
    background-color: #B31312;
    transition: all .3s;
}
.menu_btn a:hover::after {
    border-top: 3px solid #ffffff;
    border-right: 3px solid #ffffff;
}
.menu_rank_pic {
    width: 50%;
    height: auto;
    position: relative;
}
.menu_rank_img_box {
    width: 320px;
    height: 240px;
}
.menu_rank_img_box {
    position: absolute;
}
.menu_rank_img_box:nth-child(1) {
    top: -6%;
    left: 0;
}
.menu_rank_img_box:nth-child(2) {
    top: 22%;
    left: 46%;
}
.menu_rank_img_box:nth-child(3) {
    top: 60%;
    left: 2%;
}
.menu_set_plan {
    margin-bottom: 56px;
}
.menu_set_plan_title {
    text-align: center;
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 32px;
}
.menu_set_plan_title span {
    color: #B31312;
    font-size: 20px;
}
.menu_set_plan_text {
    max-width: 440px;
    margin: 0 auto 32px;
    line-height: 2.5;
    text-align: center;
}
.menu_set_plan_list {
    max-width: 720px;
    display: flex;
    margin: 0 auto;
    justify-content: space-between;
}
.menu_set_plan_items {
    position: relative;
}
.menu_set_plan_items::before {
    content: '';
    display: inline-block;
    position: absolute;
    top: 45%;
    left: 113%;
    width: 4px;
    height: 25px;
    background-color: #617A55;
}
.menu_set_plan_items::after {
    content: '';
    display: inline-block;
    position: absolute;
    top: 45%;
    left: 113%;
    width: 4px;
    height: 25px;
    background-color: #617A55;
    transform: rotate(90deg);
}
.menu_set_plan_items:last-child::before,
.menu_set_plan_items:last-child::after {
    content: none;
}

/* .localmenu_content {
    max-width: 1200px;
    margin: 0 auto 80px;
}
.localmenu_text {
    text-align: center;
    margin-bottom: 32px;
}
.localmenu_text h4 {
    font-size: 28px;
    font-weight: 700;
    letter-spacing: 0.2em;
    margin-bottom: 16px;
}
.localmenu_map_position {
    position: relative;
}
.localmenu_map_img {
    width: 50%;
    height: auto;
    margin: 0 auto;
}
.localmenu_box {
    position: absolute;
    padding: 16px;
    text-align: center;
    letter-spacing: 0.2em;
    text-shadow: 1px 1px 3px #ffffff;
    border-radius: 4px;
}
.localname {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 8px;
}
.localmenu_name {
    color: #B31312;
}
.nagasaki_position {
    top: 30%;
    left: 26%;
}
.saga_position {
    top: 14%;
    left: 31%;
}
.fukuoka_position {
    top: 4%;
    left: 43%;
}
.kumamoto_position {
    top: 36%;
    left: 46%;
}
.oita_position {
    top: 24%;
    left: 60%;
}
.miyazaki_position {
    top: 48%;
    left: 56%;
} */
.kagoshima_position {
    top: 65%;
    left: 39%;
}
.course_content {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin: 0 auto 108px;
}
.course_img {
    width: 48%;
    height: auto;
}
.course_text {
    width: 40%;
    background-color: #ffffff;
    padding: 24px;
    border-radius: 4px;
}
.course_text_title {
    width: 100%;
    text-align: center;
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 24px;
}
.course_text_title span {
    color: #B31312;
    font-size: 20px;
}
.course_text_list {
    margin-bottom: 32px;
}
.course_text_items {
    font-size: 16px;
    margin-bottom: 12px;
    text-align: center;
    letter-spacing: 0.1rem;
}
 .course_text_detail {
    font-size: 12px;
    line-height: 1.5;
    text-align: center;
 }
 .course_text_detail p span {
    color: #B31312;
 }
 /* access部分 */
.access_content {
    display: flex;
    justify-content: space-between;
}
.access_block {
    display: block;
    max-width: 560px;
}
.access_contact {
    display: flex;
}
.access_contact_logo_img {
    width: 50%;
    height: auto;
}
.access_contact_tel {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    height: auto;
    font-size: 20px;
    font-weight: 700;
}
.access_contact_tel a {
    display: inline-block;
}
.access_text {
    padding: 30px 120px 60px;
    line-height: 2.5;
    border-top: 1px solid #000000;
}
/* footer部分 */
.footer{
    text-align: center;
    padding: 16px 0;
    color: #ffffff;
    background-color: #2E3840;
}



/* menu_html部分 */
.menu_inner {
    max-width: 880px;
}
.menu_title {
    padding-top: 120px;
}
.menu_text_text_height {
    max-height: 920px;
}
.menu_text_items {
    width: 100%;
    text-align: center;
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 30px;
}
.menu_topics {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 880px;
    margin: 0 auto 120px;
}
.menu_topics_img {
    width: 50%;
    height: auto;
}
.menu_topics_price p span {
    color: #B31312;
}
.menu_name p {
    font-size: 16px;
}
.menu_sweets {
    display: block;
}
.menu_topics_img_sweets {
    width: 80%;
    margin: 0 auto 64px;
}
.menu_topics_text_sweets {
    width: 50%;
    margin: 0 auto;
    line-height: 1.7;
}
.menu_topics_text_sweets p {
    font-size: 16px;
    margin-bottom: 24px;
    text-align: justify;
}
.menu_topics_text {
    width: 44%;
    line-height: 1.7;
}
.menu_topics_text p {
    margin-bottom: 24px;
    text-align: justify;
}
.menu_topics_price {
    text-align: center;
    font-weight: 700;
}
.menu_topics_price p {
    font-size: 24px;
    text-align: center;
}
.menu_price p:nth-child(1) {
    margin-bottom: 8px;
}

/* jQuery用css */
#page-top {
	position: fixed;
	right: 10px;
	bottom:10px;
	z-index: 2;
	opacity: 0;
	transform: translateX(100px);
}
#page-top.LeftMove{
    animation: LeftAnime 0.5s forwards;
}
  @keyframes LeftAnime{
    from {
    opacity: 0;
    transform: translateX(100px);
    }
    to {
    opacity: 1;
    transform: translateX(0);
    }
  }
  /*右の動き*/
  #page-top.RightMove{
    animation: RightAnime 0.5s forwards;
  }
  @keyframes RightAnime{
    from {
    opacity: 1;
    transform: translateX(0);
    }
    to {
    opacity: 1;
    transform: translateX(100px);
    }
  }
#page-top a { 
	display: flex;
	justify-content:center;
	align-items:center;
	background: #617A55;
	border-radius: 50%;
	width: 60px;
	height: 60px;
	text-align: center;
	text-transform: uppercase; 
	text-decoration: none;
	font-size:0.6rem;
	transition:all 0.3s;
}
#page-top a span {
    width: 10px;
    height: 10px;
    border-top: 3px solid #ffffff;
    border-right: 3px solid #ffffff;
    transform: rotate(-45deg);
    margin-top: 5px;
}
#page-top a:hover {
    background: #b1cba5;
}
#top-page-link {
	position: fixed;
	right: 16px;
	top:80px;
	z-index: 2;
}
#top-page-link.LeftMove{
    animation: LeftAnime 0.5s forwards;
  }
  @keyframes LeftAnime{
    from {
    opacity: 0;
    transform: translateX(100px);
    }
    to {
    opacity: 1;
    transform: translateX(0);
    }
  }
  #top-page-link.RightMove{
    animation: RightAnime 0.5s forwards;
  }
  @keyframes RightAnime{
    from {
    opacity: 1;
    transform: translateX(0);
    }
    to {
    opacity: 1;
    transform: translateX(100px);
    }
  }
#top-page-link a { 
	display: flex;
	justify-content:center;
	align-items:center;
	background: #B31312;
    color: #ffffff;
	border-radius: 4px;
	width: 48px;
	height: 48px;
	text-align: center;
	text-transform: uppercase; 
	text-decoration: none;
	font-size:12px;
	transition:all 0.3s;
}
#top-page-link a span {
    margin-top: 5px;
}
#top-page-link a:hover {
    background: #e13939;
}



@media screen and (max-width:768px) {
    /* ハンバーガー部分 */
    .mainblur{
        filter: blur(8px);
    }
    #g-nav{
        position:fixed;
        z-index: 999;
        top:-120%;
        left: 0;
        width:100%;
        height: 100vh;
        background:rgba(255,255,255,0.95);
        transition: all 0.8s;
    }
    #g-nav.panelactive{
        top: 0;
    }
    #g-nav ul {
        position: absolute;
        z-index: 999;
        top:50%;
        left:50%;
        transform: translate(-50%,-50%);
    }
    #g-nav.panelactive ul {
        display: block;
        width: 100%;
        height: auto;
    }
    .openbtn{
        position: relative;
        background: #B31312;
        cursor: pointer;
        width: 48px;
        height:48px;
        border-radius: 5px;
        z-index: 1000;
    }
    #g-nav li{
        list-style: none;
        text-align: center; 
    }
    
    #g-nav li a{
        color: #333;
        text-decoration: none;
        padding:16px;
        display: block;
        text-transform: uppercase;
        letter-spacing: 0.1em;
        font-weight: bold;
        font-size: 18px;
    }
    .openbtn span{
        display: inline-block;
        transition: all .4s;
        position: absolute;
        left: 13px;
        height: 3px;
        border-radius: 2px;
        background: #fff;
        width: 45%;
    }
    .openbtn span:nth-of-type(1) {
        top:14px; 
    } 
    .openbtn span:nth-of-type(2) {
        top:22px;
    }
    .openbtn span:nth-of-type(3) {
        top:30px;
    }
    .openbtn.active span:nth-of-type(1) {
        top: 18px;
        left: 18px;
        transform: translateY(6px) rotate(-45deg);
        width: 30%;
    }
    .openbtn.active span:nth-of-type(2) {
        opacity: 0;
    }
    .openbtn.active span:nth-of-type(3){
        top: 30px;
        left: 18px;
        transform: translateY(-6px) rotate(45deg);
        width: 30%;
    }
    .sp_tel {
        font-weight: 700;
        font-size: 18px;
        margin-top: 24px;
    }
    .sp_inst_icon {
        width: 64px;
        height: 64px;
        margin: 0 auto;
    }



    /* header部分 */
    .header_top_title {
        font-size: 12px;
    }
    .header_top_tel ,.header_top_inst {
        display: none;
    }
    .header_items {
        display: none;
    }
    .header_main_logo img {
        width: 240px;
        height: 240px;
    }
    /* manager部分 */
    .manager_text {
        width: 100%;
        font-size: 14px;
    }
    /* shop_point部分 */
    .shop_point_box {
        flex-direction: column;
        margin-bottom: 32px;
    }
    .shop_point_box_img {
        width: 100%;
        padding: 0 16px;
    }
    .shop_point_box_text {
        width: 100%;
        font-size: 14px;
        line-height: 2;
        padding: 16px 24px;
    }
    /* .chicken_wings部分 */
    .chicken_wings_content {
        font-size: 14px;
        margin-bottom: 40px;
        padding: 16px 24px;
        line-height: 2;
    }
    .chicken_wings_make {
        justify-content: center;
    }
    .chicken_wings_make_text {
        font-size: 14px;
    }
    .chicken_wings_make_img img {
        width: 200px;
        height: 120px;
    }
    #area-3 {
        margin-bottom: 48px;
    }
    /* menu部分 */
    .menu_part {
        padding: 0 16px;
    }
    .menu_content {
        flex-direction: column;
        margin-bottom: 32px;
    }
    .menu_text {
        width: 100%;
        padding: 16px 24px;
        font-size: 16px;
    }
    .menu_text_rank {
        font-size: 20px;
    }
    .menu_rank_pic {
        width: 100%;
    }
    .menu_rank_img_box {
        position: static;
    }
    .menu_rank_img_box:nth-child(1), .menu_rank_img_box:nth-child(2) {
        display: none;
    }
    .menu_rank_img_box:nth-child(3) {
        margin: 16px auto 24px;
    }
    .menu_btn a {
        width: 240px;
        font-size: 16px;
    }
    .menu_set_plan_text p {
        font-size: 14px;
    }
    .menu_set_plan_list {
        display: block;
        text-align: center;
    }
    .menu_set_plan_items {
        margin-bottom: 24px;
    }
    .menu_set_plan_items::before {
        top: 95%;
        left: 50%;
    }
    .menu_set_plan_items::after {
        top: 95%;
        left: 50%;
    }
    .menu_set_plan_items img  {
        width: 240px;
        height: 240px;
        margin-bottom: 24px;
    }
    /* .localmenu_map_img {
        width: 100%;
    }
    .localmenu_text {
        font-size: 14px;
    }
    .localmenu_text h4 {
        font-size: 20px;
    }
    .nagasaki_position {
        top: 30%;
        left: 0%;
    }
    .saga_position {
        top: 12%;
        left: 2%;
    }
    .fukuoka_position {
        top: 1%;
        left: 29%;
    }
    .kumamoto_position {
        top: 38%;
        left: 34%;
    }
    .oita_position {
        top: 20%;
    }
    .miyazaki_position {
        top: 52%;
        left: 54%;
    }
    .kagoshima_position {
        top: 65%;
        left: 24%;
    }
    .localmenu_name {
        font-size: 14px;
    }
    .localname {
        font-size: 20px;
    } */
    .course_text {
        width: 100%;
        padding: 16px 24px;
    }
    .course_text_title {
        font-size: 20px;
    }
    .course_text_items {
        font-size: 16px;
    }
    .course_text_detail {
        font-size: 12px;
    }
    .course_img {
        width: 100%;
        padding: 16px 0;
    }
    /* access部分 */
    .access_content {
        display: block;
    }
    .access_contact_tel {
        font-size: 18px;
    }
    .access_text {
        padding: 32px;
        font-size: 14px;
    }
    .access_block {
        margin: 0 auto;
        padding: 0 16px;
    }
    .access_map {
        padding: 0 16px;
    }
    .access_map iframe {
        width: 100%;
    }



    /* menu_html部分 */
    .menu_text_margin {
        margin-bottom: 32px;
    }
    .menu_topics {
        flex-direction: column;
        margin-bottom: 64px;
    }
    .menu_topics_img {
        width: 100%;
        padding: 0 16px;
    }
    .menu_topics_text {
        width: 100%;
    }
    .menu_topics_text > p {
        font-size: 16px;
        padding: 16px;
        margin-bottom: 0;
    }
    .menu_topics_price p {
        font-size: 20px;
    }
    .menu_topics_img_sweets {
        width: 100%;
        margin: 0;
        padding: 0 16px;
    }
    .menu_topics_text_sweets {
        width: 100%;
        padding: 16px;
        font-size: 16px;
    }
    /* 共通部分 */
    section {
        margin-bottom: 120px;
    }
    .inner {
        margin-bottom: 64px;
    }
    .section_title {
        font-size: 24px;
    }
    .flex_reverse {
        flex-direction: column-reverse;
    }
    
}



@media(min-width: 768px) {
    a[href^="tel:"] {
        pointer-events: none;
    }
}