@charset "utf-8";
/*------------------------  foodcourt.css  ------------------------*/



/*-----  module  -----*/
.contents { position: relative; margin: 0 auto; padding: 0 3% 90px; max-width: 1180px; }
.contents.list { padding: 40px 3% 90px; }
.c-box { background: #fff; border-radius: 8px; overflow: hidden; box-shadow: 0 1px 6px rgba(0,0,0,0.1); }
.btn { display: flex; align-items: center; height: 48px; position: relative; padding: 0 32px 0 26px; background: #22150e; font-weight: 600; font-size: 15px; line-height: 1.3; color: #fff; border-radius: 9999px; }
.btn::after { content: ''; position: absolute; top: 50%; right: 14px; width: 16px; height: 16px; background: url(/images/ico_arrow01.svg) no-repeat; background-size: contain; transform: translate(0, -50%); }

@media screen and (max-width: 800px) {
 .contents { padding: 0 3% 40px; }
 .contents.list { padding: 20px 3% 40px; }
 .btn { justify-content: center; height: 50px; padding: 0 30px; font-size: 15px; }
 .btn::after { right: 12px; width: 14px; height: 14px; }
}




/*-----  fc-block  -----*/
.fc-block { padding: 50px 0 0; }
.fc-block .fc-block-inner { position: relative; padding: 40px 5% 55px; }
.fc-block .fc-block-inner::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 380px; background: #620000; }
.fc-block .main { position: relative; margin: 0 auto; max-width: 840px; }
.fc-block .main .main-title { padding: 0 0 35px; font-weight: 800; font-size: 30px; line-height: 1.5; color: #fff; text-align: center; }
.fc-block .main .main-txt { padding: 40px 0 50px; font-weight: 600; font-size: 16px; line-height: 1.8; }

@media screen and (max-width: 800px) {
 .fc-block { padding: 20px 0 0; }
 .fc-block .fc-block-inner { position: relative; padding: 22px 5% 35px; }
 .fc-block .fc-block-inner::before { height: 220px; }
 .fc-block .main .main-title { padding: 0 0 22px; font-size: 20px; }
 .fc-block .main .main-txt { padding: 30px 0 35px; font-size: 15px; }
}



/*-----  sso-block  -----*/
.sso-block { padding: 50px 0 0; }
.sso-block .sso-block-inner { position: relative; padding: 40px 5% 55px; }
.sso-block .sso-block-inner::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 440px; background: #004099; }
.sso-block .main { position: relative; margin: 0 auto; max-width: 840px; }
.sso-block .main .main-title { padding: 0 0 35px; font-weight: 800; font-size: 26px; line-height: 1.5; color: #fff; text-align: center; }
.sso-block .main .main-title .en { display: block; padding: 3px 0 0; font-family: 'Kanit', sans-serif; font-size: 54px; line-height: 1.3; }
.sso-block .main .main-txt { padding: 40px 0 50px; font-weight: 600; font-size: 16px; line-height: 1.8; }
.sso-block .main .access { margin: 0 auto; max-width: 600px; }
.sso-block .main .access .address { padding: 25px 0 0; font-weight: 600; font-size: 18px; line-height: 1.5; text-align: center; }

@media screen and (max-width: 800px) {
 .sso-block { padding: 20px 0 0; }
 .sso-block .sso-block-inner { position: relative; padding: 22px 5% 35px; }
 .sso-block .sso-block-inner::before { height: 260px; }
 .sso-block .main .main-title { padding: 0 0 22px; font-size: 18px; }
 .sso-block .main .main-title .en { font-size: 34px; }
 .sso-block .main .main-txt { padding: 30px 0 35px; font-size: 15px; }
 .sso-block .main .access .address { padding: 16px 0 0; font-size: 16px; }
}



/*-----  sso-map-block  -----*/
.sso-map-block { padding: 50px 0 0; }
.sso-map-block .map-block-inner { padding: 50px 5%; }
.sso-map-block .title { margin: 0 auto 18px; max-width: 314px; }
.sso-map-block .map { margin: 0 auto; max-width: 600px; }
.sso-map-block .map-notes { padding: 20px 0 0; font-size: 15px; line-height: 1.5; text-align: right; }

@media screen and (max-width: 800px) {
 .sso-map-block { padding: 30px 0 0; }
 .sso-map-block .map-block-inner { padding: 30px 5%; }
 .sso-map-block .title { margin: 0 auto 15px; max-width: 220px; }
 .sso-map-block .map-notes { padding: 20px 0 0; font-size: 14px; }
}



/*-----  sso-list-block  -----*/
.sso-list-block { padding: 50px 0 0; }
.sso-list-block .sso-list-block-inner { padding: 50px 5%; }
.sso-list-block .title { margin: 0 auto 22px; max-width: 254px; }
.sso-list-block .list-notes { padding: 25px 0 0; font-size: 15px; line-height: 1.5; }

@media screen and (max-width: 800px) {
 .sso-list-block { padding: 30px 0 0; }
 .sso-list-block .sso-list-block-inner { padding: 30px 5%; }
 .sso-list-block .title { margin: 0 auto 18px; max-width: 178px; }
 .sso-list-block .list-notes { padding: 0; font-size: 14px; }
}



/*-----  menu-block  -----*/
.menu-block { display: grid; grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(2, 1fr); grid-column-gap: 20px; grid-row-gap: 20px; }
.sso-list-block .menu-block { grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(3, 1fr); }
.menu-block .m-block { position: relative; background: #f49820; border: 3px solid #f49820; border-radius: 8px; overflow: hidden; }
.menu-block .m-block .block-info { padding: 15px 15px 196px; }
.sso-list-block .menu-block .m-block .block-info { padding: 15px 15px 124px; }
.menu-block .m-block .name { height: 52px; font-weight: 800; font-size: 20px; line-height: 1.3; }
.menu-block .m-block .shop { height: 96px; }
.menu-block .m-block .shop .shop-logo { width: 154px; }
.menu-block .m-block .shop .shop-logo2 { width: 102px; }
.menu-block .m-block .shop .shop-logo3 { width: 128px; }
.menu-block .m-block .shop .shop-logo4 { width: 174px; }
.menu-block .m-block .shop .shop-name { padding: 5px 0 0; font-weight: 600; font-size: 15px; line-height: 1.3; }
.menu-block .m-block .txt { font-size: 16px; line-height: 1.5; }
.menu-block .m-block .btn-set { position: absolute; bottom: 0; left: 0; padding: 0 15px 15px; width: 100%; }
.menu-block .m-block .pdf-btn { margin-top: 8px; }
.menu-block .m-block .pdf-btn .btn { display: flex; align-items: center; position: relative; padding: 0 20px 0 46px; }
.menu-block .m-block .pdf-btn .btn::before { content: ''; position: absolute; top: 50%; left: 14px; width: 22px; height: 22px; background: url(/images/ico_pdf.png); background-size: contain; transform: translate(0, -50%); }
.menu-block .m-block .pdf-btn .btn::after { display: none; }
.menu-block .m-block .pdf-btn .btn.menu { background: #cd001a; }
.menu-block .m-block .link-btn { margin-top: 8px; }
.menu-block .m-block .link-btn .btn { display: flex; align-items: center; position: relative; padding: 0 20px 0 48px; background: #d54b07; }
.menu-block .m-block .link-btn .btn::before { content: ''; position: absolute; top: 50%; left: 14px; width: 24px; height: 24px; background: url(/images/ico_shoplist.png); background-size: contain; transform: translate(0, -50%); }
.menu-block .m-block .link-btn .btn::after { display: none; }

@media screen and (max-width: 960px) {
 .menu-block { display: grid; grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(5, 1fr); }
}

@media screen and (max-width: 800px) {
 .menu-block { display: block; }
 .menu-block .m-block { margin: 0 0 20px; }
 .menu-block .m-block .name { height: 44px; font-size: 18px; }
 .menu-block .m-block .txt { font-size: 15px; }
 .menu-block .m-block .pdf-btn .btn { justify-content: left; }
 .menu-block .m-block .link-btn .btn { justify-content: left; }
}



/*-----  shoplist  -----*/
.shoplist { margin: 10px 0 10px; padding: 40px 45px 60px; }
.shoplist .shoplist-title { padding: 0 0 28px; border-bottom: 1px solid #dbb789; font-weight: 800; font-size: 28px; line-height: 1.3; }
.shoplist .shop-block { padding: 16px 0; border-bottom: 1px solid #dbb789; }
.shoplist .shop-block .name { font-weight: 800; font-size: 19px; line-height: 1.3; }
.shoplist .shop-block .add { padding: 6px 0 0; font-size: 15px; line-height: 1.5; }
.shoplist .list-notes { padding: 28px 0 0; font-size: 15px; line-height: 1.5; }

@media screen and (max-width: 800px) {
 .shoplist { margin: 5px 0 0; padding: 20px 5% 30px; }
 .shoplist .shoplist-title { padding: 0 0 20px; font-size: 18px; }
 .shoplist .shop-block { padding: 12px 0; }
 .shoplist .shop-block .name { font-size: 16px; }
 .shoplist .shop-block .add { padding: 4px 0 0; line-height: 1.4; }
 .shoplist .list-notes { padding: 20px 0 0; font-size: 14px; }
}



/*-----  home-btn  -----*/
.home-btn { margin: 50px auto 0; width: 240px; }

@media screen and (max-width: 800px) {
 .home-btn { margin: 30px auto 0; width: auto; }
}