@charset "utf-8";

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}
body {
    line-height:1;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
    display:block;
}
blockquote, q {
    quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}
a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}
mark {
    background-color:#ff9;
    color:#000;
    font-style:italic;
    font-weight:bold;
}
del {
    text-decoration: line-through;
}
abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}
hr {
    display:block;
    height:1px;
    border:0;
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}
input, select {
    vertical-align:middle;
}
address, caption, cite, code, dfn, em, strong, th, var {
    font-style: normal;
    font-weight: normal;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
caption, th {
    text-align: left;
}
object, embed {
    vertical-align: middle;
}
legend {
    display: none;
}
h1, h2, h3, h4, h5, h6 {
    font-size: 100%;
    font-weight: normal;
}
img, abbr, acronym, fieldset {
    border: 0 none;
}
img {
    vertical-align: middle;
}
ul li {
    list-style-type: none;
}

/*----------------------------------------------------
        共通
----------------------------------------------------*/
/* スクロールバーの有無によるズレ対策 */
html {
    overflow-y: scroll;
}

input,
textarea {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "Lucida Grande", "Lucida Sans Unicode", Arial, Verdana, sans-serif;
}

/* for IE6 */
* html body {
    font-family: "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
}

* html input,
* html textarea {
    font-family: "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
}

/* リンク
----------------------------------------------------*/
a {
    color: #333;
    text-decoration: underline;
}
a:hover {
    text-decoration: none;
}

/* 汎用
----------------------------------------------------*/
/* clear clerfix */
.clear {
    clear: both;
    display: block;
    overflow: hidden;
    visibility: hidden;
    width: 0;
    height: 0;
}

.content:after,
.clearfix:after {
    content:"";
    display:block;
    clear:both;
}

.content,
.clearfix {
    zoom: 1;
    /* for IE5.5 - IE7 */
}

/*box-sizing */
*, *:before, *:after {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

body {
    font-family:'Meiryo', 'メイリオ', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'sans-serif';
    font-size: 14px;
    background: #fff;
    line-height: 25.2px;
    color: #362e2b;
}

/*----------------------------------------------------
        各ページスタイル
----------------------------------------------------*/

/* 共通
-----------------------------------------------------------------------------------------------*/

#contents:after,
#contents_low:after {
    content: ".";
    display: block;
    visibility: hidden;
    height: 0.1px;
    font-size: 0.1em;
    line-height: 0;
    clear: both;
}

a.trance:hover {
    opacity:0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha( opacity=70 )";
}

#index p,
#category p,
#page p{
    margin: 10px 0;
}

/*----------------------------------------------------
        PCサイトcss
----------------------------------------------------*/
@media screen and (min-width: 600px) {
    #contents {
        margin: 40px auto;
        max-width: 1000px;
        width: 100%;
    }

    #index,
    #category,
    #page {
        margin-top: -20px;
        float: right;
        max-width: 740px;
        width: 74%
    }

    #side {
        float: left;
        max-width: 230px;
        width: 23%
    }

    .inner {
        margin: 0 auto;
        max-width: 1000px;
        width: 100%;
    }

    /*body*/
    body {
        color: #333;
        background: url(img/body_bg.gif) repeat left top;
    }

    #contents {
        margin: 0 auto 120px;
    }

    .sp{
        display: none;
    }

    /*header*/
    #header {
        position: relative;
        overflow: hidden;
    }

    #header .h_box {
    margin: 0 auto;
    padding: 55px 0 22px;
    display: table;
    width: 1000px;
    position: relative;
    text-align: center;
    }

    #header .site_link {
        float: right;
    }

    #header .site_link a {
        padding: 9px 22px 1px 15px;
        display: block;
        color: #FFF;
        font-size: 12px;
        line-height: 1;
        text-align: center;
        background: #D1BFAA url(img/link_icon.gif) no-repeat right 8px;
    }


    #header .top_area {
        background: #D1BFAA;
        position: absolute;
        top: 0;
        width: 100%;
    }

    #header .lead {
        padding: 4px 0 1px;
        color: #FFF;
        font-size: 12px;
        float: left;
        text-align: left;
        background-color: #D1BFAA;
    }

    #header h1,
    #header .site_ttl {
    margin: 0;
    padding: 10px 30px 10px;
    color: #6e3e2c;
    font-size: 32px;
    line-height: 1.3;
    font-weight: bold;
    }

    #header .site_ttl a {
        color: #6e3e2c;
        text-decoration: none;
    }

    #header .site_ttl a:hover {
        text-decoration: none;
        opacity: 0.6;
    }

    .menu_box {
        display: none !important;
    }

    /*g_nav*/
    #g_nav {
        background-color: #FFF;
    }

    #g_nav ul {
        display: flex;
        justify-content: center;
    }

    #g_nav ul li {
        display: inline-block;
        padding-right: 1px;
        text-align: center;
        width: 19.6%;
        background: url(img/border.gif) no-repeat left center;
    }

    #g_nav ul li:last-child {
        background:  url(img/border.gif) no-repeat left center, url(img/border.gif) no-repeat right center;
    }

    #g_nav li a {
        padding: 10px 8px 10px 11px;
        width: 100%;
        display: table;
        color: #6e3e2c;
        font-size: 16px;
        font-weight: bold;
        line-height: 1.45;
        height: 100%;
        text-decoration: none;
    }

    #g_nav li a span {
        padding: 11px 0 6px;
        display: table-cell;
        vertical-align: middle;
    }

    #g_nav li a:hover {
        color: #fff;
    }

    #g_nav li a:hover span {
        border-radius: 5px;
        background-color: #E5505E;
    }

    /*main_visual*/
    .main_visual {
        margin: 20px 0;
        min-height: 420px;
        padding: 87px 0 56px;
        background: url(img/mv-bg.png) no-repeat center top;
    }
.main_visual .mv_cara {
    position: absolute;
    right: 80px;
    bottom: -38px;
}

    .main_visual .main_img {
        display: none;
    }

    .main_visual .text_area {
        margin: 0 auto;
        padding: 0 90px;
        width: 1000px;
        position: relative;
        min-height: 267px;        
    }

    .main_visual .text_area .in_box {
        float: left;
        width: 410px;
    }

    .main_visual h2 {
        margin-bottom: 25px;
        padding-bottom: 22px;
        color: #e74d5c;
		font-size:24px;
        line-height: 1.35;
        text-align: center;
        letter-spacing: 1.5px;
        font-weight: bold;
        border-bottom: 2px solid #E5505E;
    }

    .main_visual .text_area p {
        line-height: 1.75;
    }

    /* pankuzu */
    #page_path,
    #pankuzu {
        margin: 20px auto 16px;
        max-width: 1000px;
        width: 100%;
        font-size: 12px;
        color: #5b3d32;
    }



    #pankuzu a,
    #pankuzu span {
        color: #333;
    }

    #page_path li {
        margin-right: 12px;
        display: inline;
        font-size: 12px;
        color: #333;
        vertical-align: top;
    }

    #pankuzu span:first-child {
        margin-left: 0;
    }

    #pankuzu span {
        margin: 0 4px;
        display: inline;
        font-size: 12px;
        color: #333;
        vertical-align: top;
    }

    #page_path li a {
        margin-right: 12px;
        color: #333;
    }

    /*index  category page*/
    #index {
        margin-top: -20px;
    }

    h1,h2,h3,h4,h5 {
        font-weight: bold;
        text-align: center;
    }

    #index h2,
    #category h1,
    #page h1 {
        margin: 20px 0;
        padding: 23px 40px 23px;
        color: #fff;
        font-size: 28px;
        line-height: 34px;
        min-height: 80px;
        position: relative;
        background: url(img/h2_bg01.jpg) no-repeat left top, url(img/h2_bg02.jpg) no-repeat left bottom, url(img/h2_bg03.jpg) repeat-y left 23px, url(img/h2_bg04.jpg) repeat-y right 23px;
        background-color: #E5505E;
    }

    #index h3,
    #category h2,
    #page h2 {
        margin: 25px 0;
        padding: 20px 30px 22px;
        position: relative;
        color: #6e3e2c;
        font-size: 24px;
        line-height: 1.4;
        background: url(img/h3_bg.png) no-repeat left bottom;
    }

    #index h4,
    #category h3,
    #page h3 {
        margin: 25px 0;
        padding: 12px 43px;
        color: #6e3e2c;
        font-size: 20px;
        line-height: 1.4;
        border: 1px solid #E5505E;
        background: url(img/h4_bg.gif) repeat-y left center;
    }

    #index h5,
    #category h4,
    #page h4 {
        margin: 25px 0;
        padding: 0 15px 10px 18px;
        color: #6e3e2c;
        font-size: 20px;
        line-height: 1.4;
        background: url(img/h5_bg.png) repeat-x left bottom;
    }

    .rank,
    .recommend,
    .check,
    .point {
        margin: 55px 0 30px;
        padding: 15px 15px 12px 110px;
        font-size: 24px;
        font-weight: bold;
        line-height: 1.4;
        color: #6e3e2c;
        min-height: 60px;
        position: relative;
        background-color: #fff;;
    }

    .rank:before,
    .recommend:before,
    .check:before,
    .point:before {
        margin-top: -60px;
        position: absolute;
        top: 50%;
        left: 0;
    }

    .rank:before {
    }

    .rank1:before {
        content: url("img/rank_img01.png");
    }

    .rank2:before {
        content: url("img/rank_img02.png");
    }

    .rank3:before {
        content: url("img/rank_img03.png");
    }

    .rank4:before {
        content: url("img/rank_img04.png");
    }

    .recommend:before {
        content: url("img/recommend.png");
    }

    .check:before {
        content: url("img/check.png");
    }

    .point:before {
        content: url("img/point.png");
    }

    #index ul,
    #category ul,
    #page ul{
        margin: 10px 0;
    }

    #index ul li,
    #category ul li,
    #page ul li{
        margin: 2px 0;
        padding-left: 30px;
        background: url(img/icon04.png) no-repeat 3px 5px;
    }

    #index ol,
    #category ol,
    #page ol{
        counter-reset: ol_li;
        list-style: none;
        margin: 10px 0 40px;
    }

    #index ol li,
    #category ol li,
    #page ol li{
        margin-bottom: 3px;
        padding-left: 2.11em;
        position: relative;
    }

    #index ol li:last-child,
    #category ol li:last-child,
    #page ol li:last-child {
        margin-bottom: 0;
    }

    #index ol li:before,
    #category ol li:before,
    #page ol li:before {
        margin: 1px 0 0 -27px;
        width: 20px;
        height: 20px;
        float: left;
        display: inline-block;
        color: #e74d5c;
        font-size: 16px;
        font-weight: bold;
        line-height: 1.6;
        text-align: center;
        counter-increment: ol_li;
        content: "0" counter(ol_li);
    }

    #index p span,
    #category p span,
    #page p span {
        color: #e74d5c;
        font-size: 18px;
        font-weight: bold;
        word-break: break-all;
        vertical-align: middle;
    }

    .table-layout {
        margin: 40px 20px 45px;
    }

    .table-layout table {  
        width: 100%;
        border-collapse: collapse;
    }

    .table-layout th,
    .table-layout td {
        padding: 15px 10px 11px;
        border: 1px solid #6D4032;
        text-align: center;
        line-height: 1.7;
        vertical-align: middle;
        word-wrap: break-word;
        word-break: break-all;
    }

    .table-layout th {
        color: #6e3e2c;
        font-size: 16px;
        font-weight: bold;
        background-color: #FFDEDF;
    }

    .table-layout td {
        color: #333;
        background-color: #FFF;
    }

    .table-layout::-webkit-scrollbar {
        height: 5px;
    }

    .table-layout::-webkit-scrollbar-track {
        background: #F1F1F1;
    } 

    .table-layout::-webkit-scrollbar-thumb {
        background: #BCBCBC;
    }

    #index .float-wrap,
    #category .float-wrap,
    #page .float-wrap {
        margin-bottom: 30px;
    }

    #index .float-wrap p,
    #category .float-wrap p,
    #page .float-wrap p {
        color: #362e2b;
    }

    #index .fl,
    #category .fl ,
    #page .fl {
        margin-right: 20px;
        float: left;
        width: 240px;
    }

    #index .fr,
    #category .fr ,
    #page .fr {
        margin-left: 20px;
        width: 240px;
        float: right;
    }

    #index .float-img img,
    #category .float-img img,
    #page .float-img img{
        max-width: 100%;
        border: 1px solid #c9c1b4;        
    }

    #index .fr .flame,
    #category .fr .flame,
    #page .fr .flame {
        margin-bottom: 20px;
    }

    #index .float-img .caption,
    #category .float-img .caption,
    #page .float-img .caption{
        color: #888;
        font-size: 12px;
        line-height: 1.7;
        text-align: center;
        word-wrap: break-word;
    }

    #index .btn-internal,
    #category .btn-internal,
    #page .btn-internal{
        margin: 20px auto;
        padding: 11px 45px 9px 35px;
        width: 334px;
        position: relative;
        color: #6e2e3c;
        display: block;
        font-size: 18px;
        font-weight: bold;
        line-height: 1.4;
        text-align: center;
        text-decoration: none;
        border-radius: 3px;
        border: 3px solid #6D4032;
        background: #fff url(img/icon01.png) no-repeat 297px center;
    }

    #index .btn-internal:hover,
    #category .btn-internal:hover,
    #page .btn-internal:hover{
        background-color: #DDD4C5;
    }

    #index .btn-web,
    #category .btn-web,
    #page .btn-web {
        margin: 20px auto;
        padding: 12px 45px 9px 35px;
        width: 334px;
        position: relative;
        color: #fff;
        display: block;
        font-size: 18px;
        font-weight: bold;
        line-height: 1.4;
        text-align: center;
        text-decoration: none;
        border-radius: 3px;
        border-bottom: 3px solid #6F8773; 
        background: #95B59A url(img/icon05.gif) no-repeat 300px center;
    }

    #index .btn-web:hover,
    #category .btn-web:hover,
    #page .btn-web:hover {
        padding-top: 9px;
        color: #96b79a;
        border: 3px solid #6F8773; 
        background: #fff url(img/icon08.gif) no-repeat 297px center;
    }

    #index .btn-link,
    #category .btn-link,
    #page .btn-link {
        padding: 2px 0 0 25px;
        float: right;
        color: #6e3e2c;
        font-size: 16px;
        font-weight: bold;
        background: url(img/icon01.png) no-repeat left center;
    }

    .box-wrap {
        margin: 50px 0 40px;
        display: flex;
    }

    .box-wrap .left_box{
        float: left;
        margin-right: 20px;
    }

    .box-wrap .right_box{
        float: right;
    }

    .box-wrap .box {
        padding: 10px 25px 25px;
        width: 360px;
        position: relative;
        border-radius: 30px;
        border: 5px solid #E5505E;
        background: #FFF;
    }

    .box-wrap .box-head {
        margin-bottom: 15px;
    }

    .box-wrap .box-head a{
        padding: 16px 20px 16px 0px;
        display: block;
        color: #6e3e2c;
        font-size: 18px;
        font-weight: bold;
        line-height: 1.5;
        text-decoration: none;
        background: url(img/h5_bg.png) repeat-x left bottom, url(img/icon06.png) no-repeat 284px center;
    }

    #index .box-wrap .box-body p,
    #category .box-wrap .box-body p,
    #page .box-wrap .box-body p {
        margin: 0;
        line-height: 1.72;
    }

    .box-wrap .permalink{
        height: 100%;
        left: 0;
        position: absolute;
        top: 0;
        width: 100%;
        z-index: 20;
    }

    .box-wrap .box:hover {
        background-color: #FFDEDF;
    }

    #index .frame-wrap,
    #category .frame-wrap,
    #page .frame-wrap {
        margin: 60px 0;
        display: flex;        
    }

    #index .frame-wrap .frame,
    #category .frame-wrap .frame,
    #page .frame-wrap .frame {
        margin-right: 10px;
        padding: 23px 25px 24px;
        float: left;
        width: 240px;
        background: url(img/box_bg01.jpg) no-repeat left top, url(img/box_bg02.jpg) no-repeat left bottom, url(img/box_bg03.png) repeat-y left top, url(img/box_bg04.png) repeat-y right top;
        background-color: #fff;
    }

    #index .frame-wrap .frame:last-child,
    #category .frame-wrap .frame:last-child,
    #page .frame-wrap .frame:last-child {
        margin-right: 0;
    }

    #index .frame-wrap .frame-head,
    #category .frame-wrap .frame-head,
    #page .frame-wrap .frame-head {
        margin-bottom: 15px;
        padding-bottom: 14px;
        color: #6e3e2c;
        font-size: 18px;
        font-weight: bold;
        text-decoration: none;
        text-align: center;
        border-bottom: 1px solid #6D4032;
    }

    .frame-wrap .frame-body p {
        line-height: 1.75;
    }

    #index .frame-wrap p,
    #category .frame-wrap p,
    #page .frame-wrap p{
        margin: 0;
    }

    /* side */
    #side {
        width: 23%;
        max-width: 230px;
    }

    #side .freespace {
        margin-bottom: 30px;
        padding: 59px 20px 5px;
        border: 5px solid #E5505E;
        border-radius: 120px 120px 20px 20px;
        background: #FFF url(img/s_img.png) no-repeat center 15px;
    }

    #side .freespace p {
        margin-bottom: 10px;
        line-height: 1.75;
    }

    #side .freespace .title {
        margin: 0 -2px 20px 0;
        padding: 6px 0 18px;
        font-size: 18px;
        line-height: 1.4;
        font-weight: bold;
        background: url(img/h5_bg.png) repeat-x left bottom;
    }

    #side .freespace .title a {
        display: block;
        color: #6e3e2c;
        text-decoration: none;
    }

    #side .freespace .title a:hover {
        opacity: 0.6;
    }

    #side .freespace .photo {
        margin-bottom: 15px;
    }

    #side .freespace .photo img {
        max-width: 100%;
    }

    #side .freespace .btn-internal {
        margin: 12px auto;
        padding: 7px 30px 7px 30px;
        position: relative;
        color: #6e2e3c;
        font-size: 16px;
        display: block;
        font-weight: bold;
        line-height: 1.4;
        text-align: center;
        text-decoration: none;
        border-radius: 3px;
        border: 2px solid #6D4032;
        background: #fff url(img/icon01.png) no-repeat 152px center;
    }

    #side .freespace .btn-internal:hover{
        background: #DDD4C5 url(img/icon01.png) no-repeat 152px center;
    }

    #side .cate {
        margin-bottom: 30px;
    }

    #side .cate .title {
        margin-bottom: 20px;
    }

    #side .cate .title a {
        padding: 17px 20px 15px;
        text-decoration: none;
        display: block;
        color: #6e3e2c;
        font-size: 16px;
        font-weight: bold;
        line-height: 1.5;
        text-align: center;
        border-radius: 5px;
        background-color: #fff;
        box-shadow: 0 0 0 2px #fff;
        border: 1px solid #FBD2D5;
    }

    #side .cate .title a:hover {
        background-color: #FFDEDF;
        box-shadow: 0 0 0 2px #FBD2D5;
        border: 1px solid #fff;
    }

    #side .cate .s_navi {
        margin: -20px 0 20px;
    }

    #side .cate .s_navi li {
        border-bottom: 1px solid #6D4032;
    }

    #side .cate .s_navi li a {
        padding: 13px 25px 11px;
        display: block;
        text-decoration: none;
        background: url(img/icon02.png) no-repeat 10px center;
    }

    #side .cate .s_navi li a:hover {
        color: #e74d5c;
    }

    #side .cate .s_navi .sub_cat a:hover {
        color: #96b79a;
        background: url(img/icon03.png) no-repeat 10px center;
    }

    /* footer */
    #footer {
        padding-top: 60px;
        position: relative;
        border-top: 1px solid #6D4032;
    }

    #footer .f_box {
        margin: -33px auto 0;
        width: 1000px;
        position: relative;
    }

    #footer .page_top {
        position: absolute;
        top: -152px;
        right: 0;
        z-index: 999;
    }

    #footer .page_top a {
        display: inline-block;
        width: 108px;
        height: 71px;
        background: url(img/page_top_bg.png) no-repeat left top;
    }

    #footer .page_top a:hover img {
        display: none;
    }

    #footer .f_ttl {
        margin: 33px 0 15px;
        font-size: 16px;
        background-color: #FEFDFC;
    }

    #footer .f_ttl a {
        padding: 14px 35px 12px;
        display: block;
        color: #6e3e2c;
        font-size: 18px;
        font-weight: bold;
        text-decoration: none;
        background: url(img/f_border.gif) no-repeat 20px center;
    }

    #footer .f_ttl a:hover {
        color: #e95b69;
        text-decoration: none;
    }

    #footer .f_navi {
        margin: -10px 0 33px 41px;
        display: flex;
        justify-content: left;
        flex-wrap: wrap;
    }

    #footer .f_navi li {
        margin: 10px 0 0;
        width: 19.6%;
        display: inline-block;
    }

    #footer .f_navi li a {
        padding-left: 13px;
        display: inline-block;
        color: #6e3e2c;
        text-decoration: none;
        background: url(img/icon07.png) no-repeat left 9px;
    }

    #footer .f_box .f_navi li a:hover {
        color: #e74d5c;
        text-decoration: none;
    }

    #footer .p_box {
        margin: 53px auto 27px;
        padding: 20px 19px 17px;
        width: 720px;
        color: #362e2b;
        font-size: 12px;
        line-height: 1.7;
        border: 1px solid #DFD4C5;
        background: rgba(255,255,255,0.5);
    }

    #footer .copyright {
        padding: 8px 0;
        font-size: 12px;
        color: #fff;
        text-align: center;
        line-height: 1.2;
        background-color: #D1BFAA;
    }

    #footer .copyright a {
        color: #fff;
        text-decoration: none;
    }

    #footer .copyright a:hover {
        opacity: 1;
        text-decoration: underline;
    }

}

/*----------------------------------------------------
        SPサイトcss
----------------------------------------------------*/
@media screen and (max-width: 599px) {
    #contents {
        margin: 0 auto;
        width: 100%;
    }

    .inner {
        padding: 0 3%;
    }

    .pc {
        display: none !important;
    }

    img {
        max-width: 100%;
        height: auto;
    }

    a[href^="tel:"] {
        cursor: pointer;
        pointer-events: auto;
    }

    h1,h2,h3,h4,h5 {
        margin: 15px 0;
        color: #6e3e2c;
        font-weight: bold;
        text-align: center;
    }

    #index,
    #category ,
    #page {
        margin: 0 10px;
    }

    /* body */
    body {
        color: #333;
        font-size: 13px;
        text-size-adjust: none;
        -webkit-text-size-adjust: none;
        background-color: #F8F8F0;
        background: url(img/sp/body_bg.gif) repeat left top;
    }

    body a {
        color: #333;
    }

    #contents {
        margin-bottom: 20px;
    }

    /* #page_path */	
    #pankuzu {
        margin: 0 0 0!important;
        font-size: 13px;
        color: #333;
    }

    .pankuzu {
        background: #fff;
        padding: 5px 0;
    }

    #page_path li {
        margin-right: 12px;
        display: inline;
        font-size: 13px;
        color: #333;
        vertical-align: top;
    }

    #pankuzu span:first-child {
        margin-left: 0;
    }

    #pankuzu span {
        margin: 0 4px;
        display: inline;
        font-size: 12px;
        color: #333;
        vertical-align: top;
    }

    #page_path li a {
        margin-right: 12px;
        color: #333;
    }

    #page_path li a:hover,
    #pankuzu span a:hover {
        text-decoration: underline;
    }

    /* header */
    #header {
        position: relative;
        z-index: 200;
        background-color: #EEE8DE;
    }

    #header .h_box {
        padding: 31px 20% 9px 3%;
        display: table;
        width: 100%;
    }

    #header h1,
    #header .site_ttl {
        margin: 0;
        display: table-cell;
        vertical-align: middle;
        font-size: 20px;
        font-weight: bold;
        line-height: 1.45;
        text-align: left;
        height: 55px;
    }

    #header .site_ttl a {
        color: #6e3e2c;
        text-decoration: none;
    }

    #header .lead {
        padding: 2px 0;
        width: 100%;
        color: #fff;
        font-size: 12px;
        line-height: 1;
        text-align: center;
        position: absolute;
        left: 0;
        top: 0;
        background-color: #D1BFAA;
    }

    #header .m_box {
        position: absolute;
        right: 10px;
        top: 35px;
        z-index: 999;
    }

    .menu_box {
        position: relative;
        display: none;
        z-index: 200;
        background-color: #fff;
    }

    .menu_box .close {
        margin-top: 4px;
        padding: 10px;
        font-size: 16px;
        font-weight: bold;
        color: #363636;
        text-align: center;
        cursor: pointer;
    }

    .menu_box .close a:hover {
        text-decoration: underline;
    }

    .menu_box .close span {
        margin: -5px 10px 0 0;
        display: inline-block;
        font-size: 20px;
        font-family: "游明朝体", "Yu Mincho", YuMincho, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", "ＭＳ ゴシック", sans-serif;
        line-height: 1;
        vertical-align: middle;
    }

    .menu {
        cursor: pointer;
        width: 45px;
        height: 45px;
        text-align: center;
        position: relative;
        z-index: 100;
        transition: opacity .25s ease;
        -webkit-transition: all .3s ease;
        transition: all .3s ease;
        border-radius: 8px;
        border: 2px solid #E5505E;
        background-color: #fff;
    }

    .menu.active .top {
        width: 33px;
        -webkit-transform: translateY(8px) translateX(-4px) rotate(45deg);
        -ms-transform: translateY(8px) translateX(-4px) rotate(45deg);
        transform: translateY(8px) translateX(-4px) rotate(45deg);
        z-index: 100;
    }

    .menu.active .middle {
        opacity: 0;
    }

    .menu.active .bottom {
        width: 33px;
        -webkit-transform: translateY(-8px) translateX(-4px) rotate(-45deg);
        -ms-transform: translateY(-8px) translateX(-4px) rotate(-45deg);
        transform: translateY(-8px) translateX(-4px) rotate(-45deg);
    }

    .menu span {
        margin-left: -12.5px;
        border: none;
        height: 4px;
        width: 25px;
        position: absolute;
        top: 10px;
        left: 50%;
        -webkit-transition: all .35s ease;
        transition: all .35s ease;
        cursor: pointer;
        background: #E5505E;
    }

    .menu span:nth-of-type(2) {
        top: 18px;
    }

    .menu span:nth-of-type(3) {
        top: 26px;
    }

    .menu .m_txt {
        margin-top: 15px;
        display: inline-block;
        font-size: 10px;
        color: #98CEC5;
        background: #fff;
    }

    .bg {
        position: fixed;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        z-index: 100;
        display: none;
        text-indent: -999em;
        background-color: rgba(0,0,0,0.7);
    }

    /* g_navi */
    #g_navi {
        padding: 10px;
    }

    #g_navi .ttl {
        margin-bottom: 10px;
        font-weight: bold;
    }

    #g_navi .ttl a {
    padding: 10px 30px 10px 15px;
    display: block;
    text-decoration: none;
    background: #DDD4C5 url(img/common/arrow02.png) no-repeat 95% center;
    background-size: 10px 15px;
    }

    #g_navi ul {
        margin: -10px 0 10px;
    }

    #g_navi li {
        font-weight: normal;
    }

    #g_navi li a {
    padding: 11px 30px 7px 15px;
    display: block;
    text-decoration: none;
    border-bottom: 1px solid #D7D7D7;
    background: #EEE8DE url(img/common/arrow01.png) no-repeat 95% center;
    background-size: 10px 15px;
    }

    #g_navi li:last-child a {
        border-bottom: none;
    }

    /* main_visual */
    .main_visual {
        margin: 7px 10px 30px;
        padding: 11px 15px 9px;
        border-radius: 15px;
        border: 4px solid #E5505E;
        background: url(img/sp/mv_bg.gif) repeat left top;
        background-size: 32px;
    }

    .main_visual .main_img {
        margin: 0 35px 11px;
    }

    .main_visual .main_img img {
        width: 100%;
    }

    .main_visual h2 {
        padding-bottom: 13px;
        margin: 8px 0 11px;
        color: #e74d5c;
        font-size: 20px;
        line-height: 1.4;
        text-align: left;
        background: url(img/sp/m_h2_bg.png) repeat-x left bottom;
        background-size: 30px 6px;
    }

    .main_visual p {
        font-size: 13px;
        line-height: 1.75;
    }

    /* #page_path */
    #page_path {
        margin: 14px 10px 0;
        font-size: 13px;
        color: #333;
    }

    #pankuzu {
        margin: 14px 0 0;
        font-size: 13px;
        color: #333;
    }

    #page_path li {
        margin-right: 12px;
        display: inline;
        font-size: 13px;
        color: #333;
        vertical-align: top;
    }

    #pankuzu span:first-child {
        margin-left: 0;
    }

    #pankuzu span {
        margin: 0 4px;
        display: inline;
        font-size: 12px;
        color: #333;
        vertical-align: top;
    }

    #page_path li a {
        margin-right: 12px;
        color: #333;
    }

    #page_path li a:hover,
    #pankuzu span a:hover {
        text-decoration: underline;
    }

    /* index */
    #index h2,
    #category h1,
    #page h1 {
        padding: 10px 15px 7px;
        color: #fff;
        font-size: 20px;
        text-align: center;
        line-height: 1.4;
        border-radius: 15px;
        background-color: #E5505E;
    }

    #index h3,
    #category h2,
    #page h2 {
        padding: 0 20px 15px;
        font-size: 18px;
        line-height: 1.4;
        background: url(img/sp/h3_bg01.png) no-repeat left bottom, url(img/sp/h3_bg02.png) repeat-x 3.5px bottom;
        background-size: 3.5px 10px,29px 10px;
    }


    #index h4,
    #category h3,
    #page h3 {
        padding: 7px 10px 5px;
        font-size: 16px;
        line-height: 1.4;
        border: 1px solid #E5505E;
        background: url(img/sp/h4_bg.gif) repeat left top;
        background-size: 32px;
    }

    #index h5,
    #category h4,
    #page h4 {
        padding: 7px 5px 7px 10px;
        font-size: 16px;
        line-height: 1.4;
        text-align: center;
        background: url(img/sp/h5_bg.png) repeat-x left bottom;
        background-size: 5px 2.5px;
    }

    #index ul,
    #category ul,
    #page ul {
        margin: 15px 0 12px;
    }

    #index ul li,
    #category ul li,
    #page ul li {
        margin-bottom: 5px;
        padding-left: 20px;
        font-size: 13px;
        background: url(img/sp/icon01.png) no-repeat left 7px;
        background-size: 13px 11px;
    }

    #index ul li:last-child,
    #category ul li:last-child,
    #page ul li:last-child {
        margin-bottom: 0;
    }

    #index ol,
    #category ol,
    #page ol {
        margin: 15px 0 10px;
        list-style: none;
        counter-reset: ol_li;
    }

    #index ol li,
    #category ol li,
    #page ol li {
        margin-bottom: 5px;
        padding-left: 1.5em;
        font-size: 13px;
        position: relative;
        background: none !important;
    }

    #index ol li:before,
    #category ol li:before,
    #page ol li:before {
        position: absolute;
        left: 0;
        top: 0;
        color: #e74d5c;
        font-size: 12px;
        font-weight: bold;
        text-align: center;
        counter-increment: ol_li;
        content: "0" counter(ol_li);
    }

    .rank,
    .recommend,
    .check,
    .point {
        margin: 20px 0 10px;
        padding: 8px 30px 6px 64px;
        color: #6e3e2c;
        font-size: 18px;
        font-weight: bold;
        position: relative;
        min-height: 40px;
        background-color: #fff;
    }

    .rank:before,
    .recommend:before,
    .check:before,
    .point:before {
        margin-top: -29px;
        width: 50px;
        height: 57.5px;
        position: absolute;
        top: 50%;
        left: 0;
        background-size: 50px 57.5px !important;

        content: "";
    }

    .rank1:before {
        background: url(img/sp/rank_img01.png) no-repeat;
    }

    .rank2:before {
        background: url(img/sp/rank_img02.png) no-repeat;
    }

    .rank3:before {
        background: url(img/sp/rank_img03.png) no-repeat;
    }

    .rank4:before {
        background: url(img/sp/rank_img04.png) no-repeat;
    }

    .recommend:before {
        background: url(img/sp/recommend.png) no-repeat;
    }

    .check:before {
        background: url(img/sp/check.png) no-repeat;
    }

    .point:before {
        background: url(img/sp/point.png) no-repeat;
    }

    #index p,
    #category p,
    #page p {
        margin-bottom: 20px;
    }

    #index p span,
    #category p span,
    #page p span {
        color: #e74d5c;
        font-size: 15px;
        font-weight: bold;
        vertical-align: middle;
    }

    .table-layout {
        margin: 0 0 31px;
        overflow-x: auto;
    }

    .table-layout table {
        margin-bottom: 15px;
        border-collapse: collapse;
        white-space: nowrap;
    }

    .table-layout table th,
    .table-layout table td {
        padding: 8px 20px 5px;
        font-size: 16px;
        text-align: center;
        vertical-align: middle;
        word-wrap: break-word;
        border: 1px solid #6D4032;
    }

    .table-layout table th {
        color: #6e3e2c;
        font-size: 14px;
        font-weight: bold;
        background-color: #FFDEDF;
    }

    .table-layout table td {
        background-color: #fff;
    }

    .table-layout::-webkit-scrollbar {
        height: 5px;
    }

    .table-layout::-webkit-scrollbar-track {
        background: #F1F1F1;
    } 

    .table-layout::-webkit-scrollbar-thumb {
        background: #BCBCBC;
    }

    .float-wrap {
        margin: 0 0 22px;
    }

    .float-wrap .fl,
    .float-wrap .fr {
        margin-bottom: 10px;
        text-align: center;
    }

    .float-wrap .float-img img {
        width: 100%;
        border: 1px solid #D1D1D8;
    }

    .float-wrap p {
        margin: 10px 0 !important;
        color: #3b3a4c;
        font-size: 13px;
        line-height: 1.7;
    }

    .caption {
        margin-top: 15px;
        color: #888;
        font-size: 12px;
        text-decoration: none;
        text-align: center;
        line-height: 1.2;
        word-wrap: break-word; 
    }

    .btn-web {
        margin: 20px 15px;
        padding: 11px 25px 8px 15px;
        font-size: 15px;
        color: #fff;
        font-weight: bold;
        display: block;
        text-align: center;
        text-decoration: none;
        opacity: 1;
        position: relative;
        border-radius: 3px;
        border-bottom: 3px solid #6F8773;
        background: #95B59A url(img/sp/icon03.png) no-repeat right 10px center;
        background-size: 13px;
    }

    .btn-internal {
        margin: 20px 15px;
        padding: 13px 25px 10px 15px;
        display: block;
        font-size: 15px;
        font-weight: bold;
        color: #6e3e2c;
        text-align: center;
        text-decoration: none;
        position: relative;
        border-radius: 3px;
        border: 3px solid #6D4032;
        background: #fff url(img/sp/btn_01.png) no-repeat right 7px center;
        background-size: 13px;
    }

    .btn-tel {
        margin: 20px 15px;
        padding: 13px 25px 10px 15px;
        font-size: 15px;
        color: #fff;
        font-weight: bold;
        display: block;
        text-align: center;
        text-decoration: none;
        opacity: 1;
        position: relative;
        border-radius: 3px;
        border-bottom: 3px solid #8D623A;
        background: #CA8B50 url(img/sp/icon04.png) no-repeat 10px center;
        background-size: 17.5px 20px;
    }

    .btn-link{
        margin: 20px 15px;
        padding: 13px 25px 10px 15px;
        display: block;
        font-size: 15px;
        font-weight: bold;
        color: #6e3e2c;
        text-align: center;
        text-decoration: none;
        position: relative;
        border-radius: 3px;
        border: 3px solid #6D4032;
        background: #DDD4C5 url(img/sp/btn_01.png) no-repeat right 7px center;
        background-size: 13px;
    }

    .box-wrap {
        margin-bottom: 20px;
    }

    .box-wrap .box {
        margin: 20px 0;
        padding: 0 16px 5px;
        border-radius: 10px;
        border: 4px solid #E5505E;
        background-color: #FFF;
    }

    .box-wrap .box .box-head {
        background: url(img/sp/h5_bg.png) repeat-x left bottom;
        background-size: 4.5px 2.5px;
    }

    .box-wrap .box .box-head a {
        padding: 17px 0;
        display: block;
        color: #6e3e2c;
        font-size: 15px;
        font-weight: bold;
        line-height: 1.45;
        text-decoration: none;
        background: url(img/sp/icon05.png) no-repeat right 1px center;
        background-size: 13px;
    }

    .box-wrap .box .box-body p {
        margin-bottom: 10px !important;
        line-height: 1.75;
    }

    .box-wrap .box .in_link_btn {
        margin: 10px 0;
        padding: 12px 25px 9px 15px;
        display: block;
        font-size: 15px;
        font-weight: bold;
        color: #6e3e2c;
        text-align: center;
        text-decoration: none;
        position: relative;
        border-radius: 3px;
        border: 3px solid #6D4032;
        background: #fff url(img/sp/btn_01.png) no-repeat right 7px center;
        background-size: 13px;
    }
    
    #index .frame-wrap .frame:before {
    content: "";
    position: absolute;
    height: calc(100% - 12px);
    width: calc(100% - 12px);
    border: 1px dashed #a88b80;
    top: 6px;
    left: 6px;
    border-radius: 6px;
    z-index: -1;
    }

    #index .frame-wrap .frame,
    #category .frame-wrap .frame,
    #page .frame-wrap .frame {
        margin: 20px 0;
        padding: 14px 20px 16px;
        color: #362e2b;
        border-radius: 8px;
/*        background: url(img/sp/box_bg01.gif) no-repeat left top, url(img/sp/box_bg02.gif) no-repeat right top, url(img/sp/box_bg03.gif) no-repeat left bottom, url(img/sp/box_bg04.gif) no-repeat right bottom, url(img/sp/box_bg05.gif) repeat-y left 16px, url(img/sp/box_bg06.gif) repeat-y right 16px, url(img/sp/box_bg07.gif) repeat-x 15px top, url(img/sp/box_bg08.gif) repeat-x 15px bottom;
        background-size: 16px, 16px, 16px, 16px, 12px, 12px, 12px, 12px;*/
        background-color: #fff;
        border: 1px solid #6D4032;
        position: relative;
        z-index: 1;
    }

    #index .frame-wrap .frame .frame-head,
    #category .frame-wrap .frame .frame-head,
    #page .frame-wrap .frame .frame-head {
        margin-bottom: 10px;
    }

    #index .frame-wrap .frame .frame-head p,
    #category .frame-wrap .frame .frame-head p,
    #page .frame-wrap .frame .frame-head p {
        margin: 0;
        padding-bottom: 6px;
        color: #6e3e2c;
        font-size: 15px;
        font-weight: bold;
        border-bottom: 1px solid #6D4032;
    }

    #index .frame-wrap .frame .frame-body p,
    #category .frame-wrap .frame .frame-body p,
    #page .frame-wrap .frame .frame-body p {
        margin: 0;
        line-height: 1.7;
    }

    /* side */
    #side {
        margin: 0 10px;
    }

    #side .freespace {
        margin-bottom: 40px;
        padding: 0 16px;
        border-radius: 20px;
        border: 4px solid #E5505E;
        background-color: #FFF;
    }

    #side .freespace p {
        margin: 0 0 13px;
        color: #362e2b;
        font-size: 13px;
        line-height: 1.75;
    }

    #side .freespace .title {
        margin: 0 0 15px;
        background: url(img/sp/h5_bg.png) repeat-x left bottom;
        background-size: 5px 2.5px;
    }

    #side .freespace .title a {
        padding: 15px 0 15px 45px;
        display: inline-block;
        color: #6e3e2c;
        font-size: 15px;
        font-weight: bold;
        line-height: 1.4;
        text-decoration: none;
        background: url(img/sp/s_img.png) no-repeat left center;
        background-size: 35px 25px;
    }

    #side .freespace .photo {
        margin-bottom: 10px;
    }

    #side .freespace .photo img {
        width: 100%;
    }

    #side .freespace .caption {
        margin-bottom: 12px;
        color: #666666;
        font-size: 14px;
        text-align: center;
        line-height: 1.6;
    }

    #side .freespace .btn-internal {
        margin: 15px 0;
        padding: 12px 25px 9px 15px;
        display: block;
        font-size: 15px;
        font-weight: bold;
        color: #6e3e2c;
        text-align: center;
        text-decoration: none;
        position: relative;
        border-radius: 3px;
        border: 3px solid #6D4032;
        background: #fff url(img/sp/btn_01.png) no-repeat right 7px center;
        background-size: 13px;
    }

    #side .cate {
        display: none;
    }

    /* footer */
    #footer {
        padding: 19px 10px 0;
        position: relative;
        border-top: 1px solid #6D4032;
    }

    #footer .f_box {
        margin-bottom: 8px;
    }

    #footer .f_box .page_top {
        position: fixed;
        bottom: 30px;
        right: 10px;
        z-index: 999;
    }

    #footer .page_top a img {
        width: 79px;
    }

    #footer .f_box .top_ttl {
        margin-bottom: 20px;
        text-align: center;
    }

    #footer .f_box .top_ttl a {
        padding: 10px 5px;
        display: block;
        font-size: 16px;
        font-weight: bold;
        text-decoration: none;
        background-color: #FFF;
        box-shadow: 0 0 0 2px #fff;
        border: 1px solid #FBD2D5;
    }

    #footer .f_box .f_ttl {
        margin: 10px 0;
        font-weight: bold;
        text-align: left;
        display: table;
        width: 100%;
    }

    #footer .f_box .f_ttl a {
        padding: 10px 30px;
        display: table-cell;
        color: #6e3e2c;
        font-size: 14px;
        height: 45px;
        vertical-align: middle;
        text-decoration: none;
        background: #FEFDFC url(img/sp/f_border.png) no-repeat 5px center;
        background-size: 4px 35px;
    }

    #footer .f_box .f_navi {
        margin: -10px 0 21px;
    }

    #footer .f_box .f_navi li {
        display: block;
        width: 100%;
        height: auto;
        border-bottom: 1px solid #6D4032;
    }

    #footer .f_box .f_navi li:last-child {
        margin-bottom: 0;
    }

    #footer .f_box .f_navi li a {
        padding: 12px 23px;
        display: block;
        color: #6e3e2c;
        text-decoration: none;
        background: url(img/sp/icon06.png) no-repeat 10px center;
        background-size: 9px;
    }

    #footer .p_box {
        margin-bottom: 33px;
        padding: 10px 10px;
        font-size: 12px;
        line-height: 1.54;
        border: 1px solid #E0D5C5;
        background-color: #F9F7F1;
    }

    #footer .f_site {
        margin: 15px 5px 15px;
        text-align: center;
    }

    #footer .f_site a {
        color: #6e3e2c;
        font-size: 18px;
        font-weight: bold;
        text-decoration: none;
    }

    #footer .copyright {
        margin: 0 -10px;
        padding: 13px 5px 8px;
        color: #fff;
        font-size: 12px;
        text-align: center;
        line-height: 1.5;
        background-color: #D1BFAA;
    }

    #footer .copyright a {
        color: #fff;
        text-decoration: underline;
    }
