@charset 'UTF-8';
/* ====================================================
reset style -- custom
==================================================== */
/* 
original:
html5doctor.com Reset Stylesheet
v1.6.1
*/
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
{
    font-size: 100%;

    box-sizing: border-box;
    margin: 0;
    padding: 0;
    /* font-weight: normal; */

    vertical-align: baseline;

    border: 0;
    outline: 0;
    background: transparent;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main
{
    display: block;
}

a
{
    font-size: 100%;

    margin: 0;
    padding: 0;

    vertical-align: baseline;

    background: transparent;
}

a img
{
    vertical-align: bottom;

    border: 0;
}

table
{
    border-spacing: 0;
    border-collapse: collapse;
}

hr
{
    display: block;

    height: 1px;
    margin: 1em 0;
    padding: 0;

    border: 0;
    border-top: 1px solid #ccc;
}

input,
button,
textarea,
select
{
    box-sizing: border-box;
    margin: 0;
    padding: 0;

    border: none;
    border-radius: 0;
    outline: none;
    background: none;

    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
}

select
{
    font-size: inherit;

    text-indent: .01px;
    text-overflow: '';

    color: inherit;
}

select option
{
    background-color: #fff;
}

select::-ms-expand
{
    display: none;
}

select:-moz-focusring
{
    color: transparent;
    text-shadow: 0 0 0 #828c9a;
}

input,
select
{
    vertical-align: middle;
}

input[type='submit'],
input[type='button']
{
    -webkit-box-sizing: content-box;
            box-sizing: border-box;

    border: none;
    border-radius: 0;

    -webkit-appearance: button;
       -moz-appearance: button;
            appearance: button;
}

input[type='submit']::-webkit-search-decoration,
input[type='button']::-webkit-search-decoration
{
    display: none;
}

input[type='submit']:focus,
input[type='button']:focus
{
    outline-offset: -2px;
}

img
{
    font-size: 0;
    line-height: 0;
}

small,
.small
{
    font-size: 85%;
}

/* ====================================================
Base style
==================================================== */
@font-face
{
    font-family: 'Original Yu Gothic';
    font-weight: 300;

    src: local('Yu Gothic');
}

@font-face
{
    font-family: 'Original Yu Gothic';
    font-weight: 500;

    src: local('Yu Gothic');
}

@font-face
{
    font-family: 'Original Yu Gothic';
    font-weight: bold;

    src: local('Yu Gothic');
}

html,
body
{
    width: 100%;
    height: 100%;
}

html
{
    font-size: 62.5%;
}

body
{
    /*font-family: Arial, 'Original Yu Gothic', 'Yu Gothic', YuGothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'MS Pゴシック', 'MS PGothic', sans-serif;*/
    font-family: Arial, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.7;

    box-sizing: border-box;

    color: #222;
    background: #fff;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
}

*,
*:before,
*:after
{
    box-sizing: inherit;
}

body.preload *
{
    transition: none !important;
}

/* ---------------------------
Links
--------------------------- */
a
{
    text-decoration: none;

    color: #222;
}

a:hover
{
    color: #d44830;
}

a.link-red
{
    color: #d44830;
}

a.link-red:hover
{
    color: #e69384;
}

a.outerlink
{
    padding-right: 16px;

    background: url(../img/ico_blank.png) no-repeat right 4px;
}

/* ------------------------
アンカーリンク
------------------------ */
/* ------------------------
Headline
------------------------ */
h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6
{
    font-family: inherit;
    font-weight: normal;
    line-height: 1.4;

    margin: 0;
    padding: 0;

    color: #000;
}

h1,
.h1
{
    font-size: 26px;
    font-size: 2.6rem;
}

h1 small,
.h1 small
{
    font-size: 16px;
    font-size: 1.6rem;
}

h1 .note,
.h1 .note
{
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.5;
}

h2,
.h2
{
    font-size: 24px;
    font-size: 2.4rem;
}

h2 small,
.h2 small
{
    font-size: 20px;
    font-size: 2rem;

    display: inline-block;

    margin-left: .2em;
}

h3,
.h3
{
    font-size: 18px;
    font-size: 1.8rem;
}

h4,
.h4,
h5,
.h5,
h6,
.h6
{
    font-size: 16px;
    font-size: 1.6rem;
}

/* ------------------------
プレースホルダー
------------------------ */
:placeholder-shown
{
    color: #a2a2a2;
}

::-webkit-input-placeholder
{
    color: #a2a2a2;
}

:-moz-placeholder
{
    opacity: 1;
    color: #a2a2a2;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
}

::-moz-placeholder
{
    opacity: 1;
    color: #a2a2a2;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
}

:-ms-input-placeholder
{
    color: #a2a2a2;
}

/* ====================================================
Form
==================================================== */
select,
input,
textarea,
button,
.input-filebtn
{
    /*font-family: Arial, 'Original Yu Gothic', 'Yu Gothic', YuGothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'MS Pゴシック', 'MS PGothic', sans-serif;*/
    font-family: Arial, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
    font-size: 16px;
    font-size: 1.6rem;

    display: inline-block;

    background: #f8f5f0;
}

.input-file .input-filebtn
{
    display: inline-block;

    margin-right: .5em;

    cursor: pointer;
}

.input-file .filename
{
    display: inline-block;
}

.input-file input[type='file']
{
    display: none;
}

select
{
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.4;

    padding: 6px 35px 6px 10px;

    transition: all .3s ease;
    vertical-align: middle;

    border: 1px solid #e0d9ce;
    border-radius: 3px;
    background: #f8f5f0 url(../img/img_select.png) no-repeat right center;
}

select:hover
{
    background-color: #f1eee6;
}

button,
input[type='submit']
{
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1;

    display: inline-block;

    padding: 7px 10px;

    cursor: pointer;
    transition: all .3s ease;
    text-align: center;
    vertical-align: middle;

    color: #fff;
    border: 1px solid #5d5d5d;
    border-radius: 3px;
    background: #5d5d5d;

    -webkit-font-smoothing: subpixel-antialiased;
    -moz-osx-font-smoothing: auto;
}

button:hover,
input[type='submit']:hover
{
    border-color: #d44830;
    background: #d44830;
}

input[type='text'],
input[type='search'],
input[type='tel'],
input[type='password'],
input[type='email'],
textarea,
.input-filebtn
{
    line-height: 1.4;

    padding: 6px 10px 4px;

    transition: all .3s ease;

    border: 1px solid #f8f5f0;
    border-radius: 0;
}

input[type='text']:hover,
input[type='search']:hover,
input[type='tel']:hover,
input[type='password']:hover,
input[type='email']:hover,
textarea:hover,
.input-filebtn:hover
{
    border-color: #f1eee6;
    background-color: #f1eee6;
}

input[type='text']:focus,
input[type='search']:focus,
input[type='tel']:focus,
input[type='password']:focus,
input[type='email']:focus,
textarea:focus,
.input-filebtn:focus
{
    border-color: #dfd8c5;
    background-color: #fff;
}

input[type='checkbox'],
input[type='radio']
{
    display: none;
}

input[type='checkbox'] + label,
input[type='radio'] + label
{
    position: relative;

    display: inline-block;

    cursor: pointer;
}

input[type='checkbox'] + label:before,
input[type='radio'] + label:before
{
    position: absolute;
    top: 50%;
    left: 0;

    width: 14px;
    height: 14px;
    margin-top: -8px;

    content: '';
    transition: all .3s ease;

    border: 1px solid #f1eee6;
    background: #f1eee6;
}

input[type='checkbox'] + label.ghost:before,
input[type='radio'] + label.ghost:before
{
    border: 1px solid #666;
    background: #fff;
}

input[type='checkbox'] + label:hover,
input[type='radio'] + label:hover
{
    color: #d44830;
}

input[type='checkbox'] + label:hover:before,
input[type='radio'] + label:hover:before
{
    border-color: #dfd8c5;
    background-color: #fff;
}

input[type='checkbox'] + label,
input[type='radio'] + label
{
    margin-right: 20px;
}

input[type='checkbox'] + label.mr0,
input[type='radio'] + label.mr0
{
    margin-right: 0;
}

input[type='checkbox'] + label
{
    padding: 3px 3px 3px 22px;
}

input[type='checkbox'] + label:before
{
    border-radius: 0;
}

input[type='radio'] + label
{
    padding: 3px 3px 3px 20px;
}

input[type='radio'] + label:before
{
    border-radius: 100%;
}

input[type='checkbox']:checked + label:before,
input[type='radio']:checked + label:before
{
    border-color: #fb755e;
    background: #fb755e;
}

input[type='checkbox']:checked + label:after,
input[type='radio']:checked + label:after
{
    position: absolute;

    content: '';
}

input[type='checkbox']:checked + label:after
{
    top: 10px;
    left: 2px;

    width: 11px;
    height: 5px;

    transform: rotate(-45deg);

    border-bottom: 2px solid #fff;
    border-left: 2px solid #fff;
    border-radius: 0;
}

input[type='radio']:checked + label:after
{
    top: 50%;
    left: 3px;

    width: 8px;
    height: 8px;
    margin-top: -5px;

    border-radius: 100%;
    background: #fff;
}

/* ====================================================
Pager
==================================================== */
/* ====================================================
Modal
==================================================== */
/*
.modal-content
{
    position: fixed;
    z-index: 1200;
    top: 0;
    left: 0;
    display: none;
    overflow-y: scroll;
    width: calc(100% + 100px);
    height: 100%;
    background-color: rgba(0, 0, 0, .75);
}
*/
.modal-content
{
    position: absolute;
    z-index: 1200;
    top: 0;
    left: 0;
    display: none;
    overflow-x: hidden;
    overflow-y: auto;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, .75);
}

.modal-content .modal-bg
{
    width: 100%;
    height: 100%;
}

.modal-content .modal-wrap
{
    position: absolute;
    z-index: 1201;
    top: 100px;
    left: 50%;

    width: 410px;
    margin-left: -205px;
    padding-bottom: 50px;
}

.modal-content .modal-inner
{
    padding: 5px 5px 40px;

    border-radius: 10px;
    background: #fff;
}

.modal-content .modal-inner .btn-close
{
    margin-right: -30px;

    text-align: right;
}

.modal-content .modal-inner .btn-close a
{
    font-size: 40px;
    font-size: 4rem;
    line-height: 1;

    color: #b4b4b4;
}

.modal-content .modal-inner .btn-close a:hover
{
    color: #d44830;
}

.modal-content .modal-inner .title
{
    padding: 5px 0 10px;

    text-align: center;
}

.modal-content .modal-inner .title h2,
.modal-content .modal-inner .title h3
{
    font-size: 20px;
    font-size: 2rem;
}

.modal-content .modal-inner .btnset
{
    margin-right: -10px;

    list-style: none;
}

.modal-content .modal-inner .btnset:after
{
    display: table;
    clear: both;

    content: '';
}

.modal-content .modal-inner .btnset li a
{
    display: block;
    float: left;

    width: 160px;
    margin-right: 10px;
}

.modal-content .modal-inner .btn-single
{
    text-align: center;
}

.modal-content .modal-inner .btn-single a
{
    width: 160px;
}

.modal-content .modal-inner .modal-footer,
.modal-content .modal-inner .modal-body
{
    padding: 20px 35px 0;
}

.modal-content .modal-inner .modal-header
{
    margin-right: 35px;
    margin-left: 35px;
}

.modal-content .modal-inner .modal-header.btmline
{
    padding-bottom: 30px;

    border-bottom: 1px solid #222;
}

.modal-content .modal-inner .modal-body
{
    position: relative;

    overflow: hidden;

    width: 100%;
    height: 330px;
    /*      .ps__rail-y {
        display: block;
        opacity: 1;
        height: 330px;
        background: #eee;
      }*/
}

.modal-content .modal-inner .modal-body h3
{
    font-size: 20px;
    font-size: 2rem;
}

.modal-content .modal-inner .modal-body .tag-checklist
{
    list-style: none;
}

.modal-content .modal-inner .modal-footer
{
    text-align: center;
}

.modal-content .modal-inner .error
{
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.5;

    position: relative;

    padding: 9px 10px 8px 35px;

    text-align: left;

    color: #d44830;
    background: #fdefee;
}

.modal-content .modal-inner .error:before
{
    /*font-family: Helvetica, Verdana, sans-serif;*/
    font-family: Arial, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
    font-weight: bold;
    line-height: 18px;

    position: absolute;
    top: 10px;
    left: 10px;

    width: 18px;
    height: 18px;

    content: '!';
    text-align: center;

    color: #fff;
    border-radius: 100%;
    background: #ea635c;
}

.modal-content .modal-inner .tag-input + .error,
.modal-content .modal-inner #tag-edit li a + .error
{
    margin-top: 10px;
}

.modal-content .modal-inner .tag-input
{
    width: 100%;
    margin-top: 10px;
    padding: 8px 10px 6px;

    border: 1px solid #999;
    border-radius: 3px;
    background: #fff;
}

.modal-content .modal-inner .tag-input:hover
{
    border-color: #e69384;
}

.modal-content .modal-inner .tag-input:focus
{
    border-color: #999;
}

.modal-content .modal-inner .tag-checklist
{
    margin-top: 20px;
}

.modal-content .modal-inner .tag-checklist input[type='checkbox'] + label:before
{
    border-color: #222;
    background: #fff;
}

.modal-content .modal-inner .tag-checklist input[type='checkbox'] + label:hover:before
{
    border-color: #d44830;
    background: #fbf0ee;
}

.modal-content .modal-inner .tag-checklist input[type='checkbox']:checked + label:before
{
    border-color: #d44830;
    background: #d44830;
}

.modal-content .modal-inner .tag-checklist input[type='checkbox']:checked + label:after
{
    top: 12px;
}

.modal-content .modal-inner #tag-edit
{
    list-style: none;
}

.modal-content .modal-inner #tag-edit li + li
{
    padding-top: 20px;
}

.modal-content .modal-inner #tag-edit li
{
    position: relative;
}

.modal-content .modal-inner #tag-edit li input[type='text']
{
    width: 295px;
    padding: 8px 10px 6px;

    border-radius: 3px;
}

.modal-content .modal-inner #tag-edit li input[type='text'].edit
{
    color: #222;
    border-color: #f1eee6;
    background: #f1eee6;
}

.modal-content .modal-inner #tag-edit li input[type='text'].active
{
    border-color: #e0d9ce;
    background: #f9f8f4;
}

.modal-content .modal-inner #tag-edit li input[type='text'].active:hover
{
    background: #fff;
}

.modal-content .modal-inner #tag-edit li input[type='text'].active:focus
{
    border-color: #e0d9ce;
    background: #f9f8f4;
}

.modal-content .modal-inner #tag-edit li input[type='text'].del
{
    color: #e8e8e8;
    border-color: #a3a3a3;
    background: #a3a3a3;
}

.modal-content .modal-inner #tag-edit li .icon-edit
{
    position: absolute;
    right: 40px;
    bottom: 0;
}

.modal-content .modal-inner #tag-edit li .icon-edit:before
{
    font-size: 26px;
    font-size: 2.6rem;

    position: relative;
    bottom: 4px;
}

.modal-content .modal-inner #tag-edit li .icon-delete,
.modal-content .modal-inner #tag-edit li .icon-reflesh
{
    line-height: 1;

    display: inline-block;

    width: 25px;
    margin-left: 10px;

    cursor: pointer;
    text-align: center;

    color: #5d5d5d;
}

.modal-content .modal-inner #tag-edit li .icon-delete:before,
.modal-content .modal-inner #tag-edit li .icon-reflesh:before
{
    font-size: 26px;
    font-size: 2.6rem;

    position: relative;
    top: 0;

    vertical-align: top;
}

.modal-content .modal-inner #tag-edit li .icon-delete:hover,
.modal-content .modal-inner #tag-edit li .icon-reflesh:hover
{
    color: #d44830;
}

.modal-content#modal-clip-edit
{
    /*    .ps__rail-y {
      height: 350px;
    }*/
}

.modal-content#modal-clip-edit .modal-body
{
    height: 350px;
}

.modal-content#modal-clip-edit .tag-input
{
    width: 295px;
    margin-right: 35px;
}

/* ====================================================
Button
==================================================== */
.btn
{
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1;

    display: inline-block;

    padding: .6em 1.5em;

    cursor: pointer;
    transition: all .3s ease;
    text-align: center;
    text-decoration: none;

    color: #fff;
    border: none;
    border-radius: 3px;
    background: #5d5d5d;

    -webkit-font-smoothing: subpixel-antialiased;
    -moz-osx-font-smoothing: auto;
}

.btn:hover
{
    color: white;
    background: #909090;
}

.btn.btn-ghost
{
    color: #5d5d5d;
    border: 1px solid #5d5d5d;
    background: #fff;
}

.btn.btn-ghost:hover
{
    color: #fff;
    background: #5d5d5d;
}

.btn.btn-ghost-red
{
    color: #d44830;
    border: 2px solid #d44830;
    background: #fff;
}

.btn.btn-ghost-red:hover
{
    color: #fff;
    background: #d44830;
}

.btn.btn-white
{
    color: #222;
    background: #fff;
}

.btn.btn-white:hover
{
    color: white;
    background: #6f6f6f;
}

.btn.btn-dark
{
    color: #fff;
    background: #222;
}

.btn.btn-dark:hover
{
    color: white;
    background: #6f6f6f;
}

.btn.btn-clip
{
    width: 90px;
    height: 30px;
    padding: 0;

    transition: all .3s ease;
    text-align: center;

    color: #666;
    background: #f1eee6;
}

.btn.btn-clip .icon-clip
{
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 30px;
    line-height: 30px;

    display: inline-block;

    margin-top: -1px;
    margin-left: -5px;
}

.btn.btn-clip .icon-clip:before
{
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 30px;

    position: relative;
    top: .1em;

    margin-right: 5px;

    vertical-align: top;

    color: #d44830;
}

.btn.btn-clip.btn-md
{
    width: 340px;
    height: 50px;

    vertical-align: middle;
}

.btn.btn-clip.btn-md .icon-clip
{
    font-size: 20px;
    font-size: 2rem;
    line-height: 52px;
}

.btn.btn-clip.btn-md .icon-clip:before
{
    font-size: 28px;
    font-size: 2.8rem;
    line-height: 52px;
}

.btn.btn-clip:hover
{
    color: #d44830;
    background: #e4dfd2;
}

.btn.btn-clip.active
{
    color: #fff;
    background: #d44830;
}

.btn.btn-clip.active .icon-clip:before
{
    color: #fff;
}

.btn-lg,
.btn-md,
.btn-sm
{
    line-height: 1.5;

    padding: 6px 10px;
}

.btn-lg
{
    font-size: 18px;
    font-size: 1.8rem;
}

.btn-md
{
    font-size: 16px;
    font-size: 1.6rem;
}

.btn-sm
{
    font-size: 14px !important;
    font-size: 1.4rem !important;

    width: 140px;
}

.icon-arrow-right.right
{
    display: inline-block;
    float: right;
}

.icon-arrow-right.right.btn-lg
{
    font-size: 18px;
    font-size: 1.8rem;

    margin: 10px -15px 10px 0;
}

.icon-arrow-right.right.btn-lg:after
{
    font-size: 28px;
    font-size: 2.8rem;
}

.icon-arrow-right.right.btn-md
{
    font-size: 16px;
    font-size: 1.6rem;

    margin: 10px -12px 10px 0;
}

.sidenav + p.clearfix .icon-arrow-right.right.btn-md
{
    margin: 0;
    padding-right: 0;
}


.icon-arrow-right.right.btn-md:after
{
    font-size: 22px;
    font-size: 2.2rem;
}

.btn-more
{
    font-size: 18px;
    font-size: 1.8rem;

    display: -ms-flexbox;
    display: flex;

    width: 200px;
    height: 200px;

    transition: all .3s ease;

    background: #f1eee6;

    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-align: center;
    align-items: center;
}

.btn-more.icon-plus:before
{
    font-size: 30px;
    font-size: 3rem;

    margin: 2px 2px 0 -5px;

    color: #d44830;
}

.btn-more:hover
{
    color: #d44830;
    background: #e4dfd2;
}

@font-face
{
    font-family: 'icomoon';
    font-weight: normal;
    font-style: normal;

    src: url('fonts/icomoon.eot?bm2x8b');
    src: url('fonts/icomoon.eot?bm2x8b#iefix') format('embedded-opentype'), url('fonts/icomoon.ttf?bm2x8b') format('truetype'), url('fonts/icomoon.woff?bm2x8b') format('woff'), url('fonts/icomoon.svg?bm2x8b#icomoon') format('svg');
}

[class^='icon-'],
[class*=' icon-']
{
    /* アイコン以外の日本語文字がブラウザ初期設定のフォントになってしまう為、指定の日本語フォント追記 */
    /*font-family: 'icomoon', Arial, 'Original Yu Gothic', 'Yu Gothic', YuGothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'MS Pゴシック', 'MS PGothic', sans-serif !important;*/
    font-family: 'icomoon', Arial, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "MS Pゴシック", "MS PGothic", sans-serif!important;
    font-weight: normal;
    font-style: normal;
    font-variant: normal;
    line-height: 1;

    text-transform: none;

    speak: none;
}

/* windowsメイリオ環境用 */
.icon-arrow-left:before
{
    content: '\e900';
}

.icon-arrow-right:before
{
    content: '\e901';
}

.icon-cart:before
{
    content: '\e902';
}

.icon-catalogue:before
{
    content: '\e903';
}

.icon-category:before
{
    content: '\e904';
}

.icon-clip:before
{
    content: '\e905';
}

.icon-close:before
{
    content: '\e906';
}

.icon-feature:before
{
    content: '\e907';
}

.icon-history:before
{
    content: '\e908';
}

.icon-login:before
{
    content: '\e909';
}

.icon-plus:before
{
    content: '\e90a';
}

.icon-ranking:before
{
    content: '\e90b';
}

.icon-search:before
{
    content: '\e90c';
}

.icon-arrow-btm:before
{
    content: '\e90f';
}

.icon-delete:before
{
    content: '\e910';
}

.icon-edit:before
{
    content: '\e911';
}

.icon-reflesh:before
{
    content: '\e912';
}

.icon-crown:before
{
    content: '\e90d';
}

.icon-plus-circle:before
{
    content: '\e90e';
}

.icon-facebook:before
{
    content: '\e913';
}

.icon-twitter:before
{
    content: '\e914';
}

.icon-close-solid:before
{
    content: '\e915';
}

.icon-food:before
{
    content: '\e916';
}

.icon-timer:before
{
    content: '\e917';
}

.icon-line:before
{
    content: '\e918';
}

.icon-arrow-right.right:before
{
    content: '';
}

.icon-arrow-right.right:after
{
    content: '\e901';
    vertical-align: middle;
}

/* ====================================================
layout style
==================================================== */
#container
{
    position: relative;

    width: 100%;
    min-width: 1200px;
    height: auto !important;
    height: 100%;
    min-height: 100%;
}

#container:after
{
    display: table;
    clear: both;

    content: '';
}

#body
{
    margin-left: 240px;
    padding: 30px 30px 300px;
}

#side
{
    position: fixed;
    z-index: 999;
    top: 0;
    bottom: 0;
    left: 0;

    width: 240px;

    background: #f1eee6;
}

#side > .inner
{
    position: relative;

    overflow: hidden;

    width: 100%;
    height: 100%;
}

#side .sitelogo
{
    display: block;

    width: 214px;
    margin: 30px 0 40px 15px;
}

#side .sidefree
{
    margin: 0 20px 20px;
}

/* section */
.sec
{
    margin-top: 50px;
}

.sec > .sec-header
{
    margin-bottom: 20px;
}

.sec .sec
{
    margin-top: 30px;
}

.sec .sec > .sec-header
{
    margin-bottom: 12px;
}

.page-footer
{
    padding: 30px 0 0;
}

.page-footer .clip
{
    float: left;
}

.page-footer .sns
{
    float: right;

    padding-top: 30px;
}

.page-footer .sns .fb-share-button
{
    top: -8px;
}

/* ------------------------
フリースペース
------------------------ */
.freearea
{
    margin-top: 50px;
}

/* ------------------------
ページタイトル
------------------------ */
.page-header
{
    padding-top: 10px;
}

.page-header h1
{
    display: inline-block;
}

.page-header h1 small
{
    font-size: 20px;
    font-size: 2rem;

    margin-left: 10px;
}

.page-header h1 .note
{
    font-size: 14px;
    font-size: 1.4rem;
}

.page-header .lead
{
    font-size: 14px;
    font-size: 1.4rem;

    margin-top: 10px;
}

.page-header .number
{
    font-size: 26px;
    font-size: 2.6rem;

    display: inline-block;

    margin-left: 20px;
}

.page-header .number small
{
    font-size: 20px;
    font-size: 2rem;

    margin-left: 4px;
}

/* ------------------------
レシピ検索フォーム
------------------------ */
.searchform
{
    margin-top: 30px;
    padding-bottom: 30px;

    border-bottom: 1px dashed #d4cec4;
}

.searchform .dl-table
{
    font-size: 14px;
    font-size: 1.4rem;
}

.searchform .dl-table dt
{
    font-weight: normal;

    width: 120px;
    padding: 0 20px 20px 0;

    white-space: nowrap;
}

.searchform .dl-table dd
{
    overflow: hidden;

    padding: 0 0 20px;
}

.searchform .dl-table dd .searchbox-word
{
    font-size: 12px;
    font-size: 1.2rem;

    width: 200px;
}

.searchform .dl-table dd select
{
    display: inline-block;

    min-width: 90px;
    margin-right: 7px;
}

.searchform .dl-table dd select#years
{
    min-width: 110px;
}

.searchform .searchbox-list
{
    list-style: none;
}

.searchform .searchbox-list li
{
    display: inline-block;
}

.searchform input[type='submit'].btn
{
    margin-top: 10px;
    margin-left: 120px;
}

.no-result .hint
{
    width: 650px;
    padding: 30px;

    background: #f1eee6;
}

.no-result .hint li
{
    font-size: 14px;
    font-size: 1.4rem;
}

.no-result .hint li + li
{
    padding-top: 5px;
}

.no-result .hint .icon-arrow-right.right
{
    font-size: 18px;
    font-size: 1.8rem;

    float: none;
}

/* ------------------------
レシピ一覧
------------------------ */
.sort ul
{
    font-size: 14px;
    font-size: 1.4rem;

    margin-bottom: 30px;

    list-style: none;
}

.sort ul li
{
    line-height: 1.1;

    display: inline-block;

    margin-right: 20px;
}

.sort ul li .active
{
    font-weight: normal;

    color: #d44830;
}

.sort ul li + li
{
    padding-left: 20px;

    border-left: 1px solid #222;
}

.lists ul
{
    display: -ms-flexbox;
    display: flex;

    margin-right: -30px;
    padding-top: 2px;

    list-style: none;

    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
}

.lists ul .item
{
    display: -ms-flexbox;
    display: flex;

    width: 200px;
    margin: 0 30px 30px 0;

    -ms-flex: 0 1 200px;
        flex: 0 1 200px;
    -ms-flex-flow: column;
        flex-flow: column;
}

.lists ul .item > a
{
    position: relative;

    display: -ms-flexbox;
    display: flex;

    height: 100%;

    -ms-flex-flow: column;
        flex-flow: column;
}

.lists ul .item > a .desc,
.lists ul .item > a .cite
{
    color: #666;
}

.lists ul .item > a:hover .desc,
.lists ul .item > a:hover .cite
{
    color: #d44830;
}

.lists ul .item .thumb
{
    position: relative;
}

.lists ul .item .thumb .noimg
{
    font-size: 18px;
    font-size: 18px;
    font-size: 1.8rem;

    position: absolute;
    top: 0;
    left: 0;

    display: -ms-flexbox;
    display: flex;

    width: 100%;
    height: 100%;

    text-align: center;

    color: #fff;
    background-color: rgba(0, 0, 0, .7);

    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.lists ul .item .thumb img
{
    font-family: 'object-fit: cover;';

    width: 200px;
    height: 200px;

    transition: opacity .3s ease;

    opacity: 1;
    opacity: 1.0;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
    object-fit: cover;
    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
}

.lists ul .item .thumb img:hover
{
    opacity: .6;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=60)';
}

.lists ul .item .title
{
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 1.4;

    padding-top: 10px;
}

.lists ul .item .title.title-sm
{
    font-size: 14px;
    font-size: 1.4rem;
}

.lists ul .item .desc,
.lists ul .item .cite
{
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1.5;

    display: block;

    padding-top: 7px;
}

.lists ul .item .cite
{
    font-style: normal;

    margin-top: auto;
}

.lists ul .item .desc + .cite
{
    margin-top: 0;
}

.lists ul .item .clip
{
    margin-top: auto;
    padding-top: 8px;
}

.lists.list-single,
.lists .list-single
{
    overflow: hidden;

    width: 100%;
    max-height: 250px;
    /* トップ新着のように、画面幅いっぱい画像途中でも表示する場合
    ul {
      flex-wrap: nowrap;
    } 
    */
}

.lists.list-narrow.list-single,
.lists .list-narrow.list-single
{
    max-height: 235px;
}

.lists.list-sm .item,
.lists .list-sm .item
{
    width: 165px;

    -ms-flex: 0 1 165px;
        flex: 0 1 165px;
}

.lists.list-sm .item .thumb img,
.lists .list-sm .item .thumb img
{
    width: 165px;
    height: 165px;
}

.lists.list-sm .item .title,
.lists .list-sm .item .title
{
    font-size: 14px;
    font-size: 1.4rem;
}

.lists.list-lg .item,
.lists .list-lg .item
{
    width: 330px;

    -ms-flex: 0 1 330px;
        flex: 0 1 330px;
}

.lists.list-lg .item .thumb img,
.lists .list-lg .item .thumb img
{
    width: 330px;
    height: 330px;
}

.lists.list-liquid,
.lists .list-liquid
{
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
}

.lists.list-liquid .item,
.lists .list-liquid .item
{
    width: 100%;

    -ms-flex: 0 1 100%;
        flex: 0 1 100%;
}

.lists.list-liquid .item .thumb img,
.lists .list-liquid .item .thumb img
{
    width: 100%;
    height: 100%;
}

.lists.list-narrow ul,
.lists .list-narrow ul
{
    margin-right: -20px;
}

.lists.list-narrow ul .item,
.lists .list-narrow ul .item
{
    margin-right: 20px;
    margin-bottom: 20px;
}

/* ------------------------
ランキング
------------------------ */
.ranking ul .item
{
    position: relative;

    padding-bottom: 20px;

    vertical-align: top;
}

.ranking ul .item .label-ranking
{
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1;

    position: absolute;
    z-index: 100;
    top: -2px;
    left: 5px;

    width: 28px;
    height: 35px;
    padding-top: 10px;

    text-align: center;

    background: url(../img/ico_ranking_s.png) no-repeat top left;
}

.ranking ul .item .label-ranking.rank1,
.ranking ul .item .label-ranking.rank2,
.ranking ul .item .label-ranking.rank3
{
    width: 37px;
    height: 47px;
    padding-top: 20px;

    color: #fff;
}

.ranking ul .item .label-ranking.rank1
{
    background: url(../img/ico_ranking01_s.png) no-repeat top left;
}

.ranking ul .item .label-ranking.rank2
{
    background: url(../img/ico_ranking02_s.png) no-repeat top left;
}

.ranking ul .item .label-ranking.rank3
{
    background: url(../img/ico_ranking03_s.png) no-repeat top left;
}

.ranking.list-lg .item .label-ranking.rank1,
.ranking.list-lg .item .label-ranking.rank2,
.ranking.list-lg .item .label-ranking.rank3,
.ranking .list-lg .item .label-ranking.rank1,
.ranking .list-lg .item .label-ranking.rank2,
.ranking .list-lg .item .label-ranking.rank3
{
    font-size: 20px;
    font-size: 2rem;

    left: 10px;

    width: 47px;
    height: 59px;
    padding-top: 24px;

    text-indent: -1px;
}

.ranking.list-lg .item .label-ranking.rank1,
.ranking .list-lg .item .label-ranking.rank1
{
    text-indent: -4px;

    background: url(../img/ico_ranking01.png) no-repeat top left;
}

.ranking.list-lg .item .label-ranking.rank2,
.ranking .list-lg .item .label-ranking.rank2
{
    background: url(../img/ico_ranking02.png) no-repeat top left;
}

.ranking.list-lg .item .label-ranking.rank3,
.ranking .list-lg .item .label-ranking.rank3
{
    background: url(../img/ico_ranking03.png) no-repeat top left;
}

/* ------------------------
ページャー
------------------------ */
.pager
{
    text-align: center;
}

.pager ul
{
    font-size: 17px;
    font-size: 1.7rem;

    list-style: none;
}

.pager ul li
{
    display: inline-block;

    margin: 0 5px;
}

.pager ul li a,
.pager ul li .active
{
    line-height: 24px;

    display: inline-block;

    width: 24px;
    height: 24px;

    text-align: center;
    vertical-align: middle;
}

.pager ul li a.icon-arrow-right,
.pager ul li a.icon-arrow-left
{
    font-size: 24px;
    font-size: 2.4rem;
}

.pager ul li .active
{
    font-weight: normal;

    color: #d44830;
}

/* ------------------------
特集一覧
------------------------ */
.lists-special ul
{
    width: 930px;

    list-style: none;
}

.lists-special ul:after
{
    display: table;
    clear: both;

    content: '';
}

.lists-special ul li
{
    float: left;

    width: 280px;
    margin: 0 30px 30px 0;
}

.lists-special ul li img
{
    font-family: 'object-fit: cover;';

    width: 280px;
    height: 200px;

    transition: opacity .3s ease;

    opacity: 1;
    opacity: 1.0;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
    object-fit: cover;
    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
}

.lists-special ul li img:hover
{
    opacity: .6;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=60)';
}

/* ------------------------
クリップ一覧
------------------------ */
#toggle-btn
{
    font-size: 14px;
    font-size: 1.4rem;

    border-width: 1px;
}

#toggle-btn:after
{
    position: relative;
    top: 12px;

    width: 0;
    height: 0;
    margin-left: 5px;

    content: '';

    border-width: 6px 4px 0 4px;
    border-style: solid;
    border-color: #d44830 transparent transparent transparent;
}

#toggle-btn:hover:after
{
    border-color: #fff transparent transparent transparent;
}

#toggle-btn.active:after
{
    top: -11px;

    border-width: 0 4px 6px 4px;
    border-color: transparent transparent #d44830 transparent;
}

#toggle-btn.active:hover:after
{
    border-color: transparent transparent #fff transparent;
}

#toggle-menu
{
    display: none;
}

.searchform .dl-table .clip-tag
{
    width: 780px;
}

.searchform .dl-table .clip-tag ul
{
    font-size: 0;

    display: inline;
}

.searchform .dl-table .clip-tag ul li
{
    display: inline-block;
}

.searchform .dl-table .clip-tag ul li a
{
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1;

    display: inline-block;

    margin-right: 10px;
    margin-bottom: 10px;
    padding: 7px 20px;

    transition: background .3s ease, border .3s ease;
    text-align: center;

    border: 1px solid #c5c1b6;
    border-radius: 3px;
    background: #fff;
}

.searchform .dl-table .clip-tag ul li a:hover
{
    color: #222;
    background: #f2f1ef;
}

.searchform .dl-table .clip-tag ul li a.active
{
    font-weight: bold;

    color: #fff;
    border-color: #d44830;
    background: #d44830;
}

.searchform .dl-table .clip-tag .clip-edit
{
    font-size: 0;
    line-height: 1;
}

.searchform .dl-table .clip-tag .clip-edit:before
{
    font-size: 25px;
    font-size: 2.5rem;
    line-height: 1;

    position: relative;
    top: 4px;

    vertical-align: top;
}

.search-condition
{
    font-size: 12px;
    font-size: 1.2rem;

    margin-bottom: 20px;
}

.search-condition dt,
.search-condition dd
{
    padding: 0 20px 5px 2px;
}

/* 20180108add start */
.clip-example {
	background: url("../../img/img_clip_ex_pc.png") no-repeat;
	width: 730px;
	height: 414px;
}
.clip-example p {
	padding: 111px 56px 0 331px;
	letter-spacing: .02em;
}
.clip-example p a {
	text-decoration: underline;
}
.clip-example p a:hover {
	text-decoration: none;
}
.sec-header.clip-hukidasi {
  position: relative;
  display: inline-block;
  padding-right: 150px;
  margin-top: 85px;
}
.sec-header.clip-hukidasi::before {
  content: '';
  display: block;
  position: absolute;
  width: 141px;
  height: 80px;
  background: url(../../img/img_clip_hukidasi_pc.png) no-repeat;
  right: 0;
  bottom: 16px;
}
/* 20180108add end */

/* ====================================================
Header
==================================================== */
#header
{
    float: left;

    width: 240px;
}

#header .header-title
{
    font-size: 16px;
    font-size: 1.6rem;

    display: block;

    padding: 30px 20px;

    color: #fff;
}

#header .header-title a
{
    color: #fff;
}

/* ====================================================
Footer
==================================================== */
#footer
{
    font-size: 14px;
    font-size: 1.4rem;

    position: absolute;
    bottom: 0;
    left: 240px;

    width: calc(100% - 240px);
}

#footer .breadcrumb
{
    padding: 25px 30px;

    border-top: 1px solid #e5e2db;
    border-bottom: 1px solid #e5e2db;
}

#footer .breadcrumb ul
{
    overflow: hidden;
}

#footer .breadcrumb ul:after
{
    display: table;
    clear: both;

    content: '';
}

#footer .breadcrumb ul li
{
    line-height: 1.5;

    float: left;

    list-style: none;
}

#footer .breadcrumb ul li a
{
    color: #d44830;
}

#footer .breadcrumb ul li a:hover
{
    color: #e68271;
}

#footer .breadcrumb ul li + li:before
{
    margin: 0 5px;

    content: '>';
}

#footer #footer-main
{
    padding: 25px 30px 30px;
}

#footer #footer-main .footer-nav:after
{
    display: table;
    clear: both;

    content: '';
}

#footer #footer-main .footer-nav li
{
    float: left;

    margin-right: 30px;

    list-style: none;
}

#footer #footer-main .footer-nav li a
{
    line-height: 1.9;
}

#footer #footer-main .copyright
{
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1;

    display: block;

    margin-top: 20px;

    letter-spacing: .05em;
}

/* ====================================================
Navigation
==================================================== */
#globalnav
{
    padding-bottom: 30px;
}

#globalnav li
{
    list-style: none;
}

#globalnav .sidesec
{
    margin: 0 20px 30px;
}

#globalnav .sidesec .side-title
{
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: normal;

    margin-bottom: 10px;
    padding-bottom: 5px;

    border-bottom: 1px solid #d7d3cb;
}

#globalnav .sidesec .side-title a,
#globalnav .sidesec .side-title span
{
    display: block;

    margin-bottom: 3px;
}

#globalnav .sidenav > li
{
    padding: 4px 0;
}

#globalnav .sidenav > li > a
{
    display: block;

    padding: 1px 0;
}

#globalnav .sidesec .sidenav > li > a
{
    margin-left: 30px;
    min-height: 26px;
    padding-top: 8px;
}

#globalnav .sidesec .sidenav > li > a[class^='icon-']:before {
    position: absolute;
    left: 0;
    top: 8px;
}

#globalnav .sidenav > li.trigger
{
    cursor: pointer;
}

#globalnav .sidenav > li.trigger:hover
{
    color: #d44830;
}

#globalnav .sidenav > li.trigger.active:after
{
    position: absolute;
    top: 50%;
    right: -20px;

    width: 0;
    height: 0;
    margin-top: -4px;

    content: '';

    border-width: 6px 10px 6px 0;
    border-style: solid;
    border-color: transparent #3b3b39 transparent transparent;
}

#globalnav .sidenav > li + li.trigger.active:after
{
    margin-top: 0;
}

#globalnav .sidenav > li.current
{
    margin: 0 -20px;
    padding: 0 20px 5px;

    background: #fff;
}

#globalnav .sidenav > li.current.active:after
{
    right: 0;
}

#globalnav .sidenav > li.current > a
{
    margin-top: 2px;
    margin-bottom: 2px;

    color: #d44830;
}

#globalnav .sidenav > li.current > a:before
{
    color: #d44830;
}

#globalnav .sidenav > li.current input[type='text']#side-searchbox
{
    border-color: #f8f5f0;
    background: #f8f5f0;
}

#globalnav .sidenav > li.current input[type='submit']#side-searchbtn
{
    border-color: #d44830;
    background: #d44830;
}

#globalnav #side-search
{
    display: inline-block;

    margin-left: -5px;
}

#globalnav #side-search:hover input[type='submit']#side-searchbtn
{
    border-color: #d44830;
    background: #d44830;
}

#globalnav input[type='text']#side-searchbox
{
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 24px;

    width: 135px;
    height: 24px;
    padding: 0 7px;

    border-color: #fff;
    background: #fff;
}

#globalnav input[type='submit']#side-searchbtn
{
    font-size: 12px;
    font-size: 1.2rem;

    width: 30px;
    height: 24px;
    padding: 0;

    color: #fff;
    border-color: #000;
    border-radius: 0;
    background: #000;
}

#globalnav input[type='submit']#side-searchbtn:hover
{
    border-color: #d44830;
    background: #d44830;
}

#globalnav .icon-search
{
    display: inline-block;

    margin-bottom: 5px;
    padding: 1px 0;

    cursor: pointer;
}

#globalnav a[class^='icon-']:before,
#globalnav span[class^='icon-']:before
{
    font-size: 24px;
    font-size: 2.4rem;

    position: relative;
    top: .1875em;

    margin-right: 5px;
}

#globalnav a.icon-ranking:before
{
    top: .1em;
}

#globalnav .arrow,#globalnav .side-title span
{
    /*font-family: 'icomoon', Arial, 'Original Yu Gothic', 'Yu Gothic', YuGothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'MS Pゴシック', 'MS PGothic', sans-serif !important;*/
    font-family: 'icomoon', Arial, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "MS Pゴシック", "MS PGothic", sans-serif !important;
}

#globalnav .arrow:after
{
    font-size: 24px;
    font-size: 2.4rem;
    line-height: 1;

    position: relative;
    top: .1875em;

    float: right;

    margin-right: -10px;

    content: '\e901';
    transition: opacity .3s ease;

    opacity: 0;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=0)';
}

#globalnav .sidenav li
{
    position: relative;
}
#globalnav .sidenav .arrow:after
{
    position: absolute;
    
    margin-right:auto;
    
    display: inline;

    right: -10px;
    top: 50%;
    transform: translateY(-50%);
    padding-top: .1875em;
}

#globalnav .nav-pal .arrow:after,
#globalnav .nav-logout .arrow:after
{
    right: 5px;
}

#globalnav .arrow:hover:after
{
    opacity: 1;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
}

#globalnav .side-title .arrow:after
{
    top: .1em;
}

#globalnav .nav-pal a,
#globalnav .nav-logout a
{
    display: block;

    margin: 0 16px 15px;
}

/* モーダルメニュー */
.sidenav li.trigger .modalmenu
{
    position: fixed;
    z-index: 1000;
    top: 0;
    bottom: 0;
    left: 240px;

    overflow: hidden;

    width: 480px;
    height: 100%;
    max-height: 0;
    padding: 0;

    opacity: 0;
    background-color: rgba(49, 49, 49, .95);

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=0)';
}

.sidenav li.trigger .modalmenu .ps__rail-y:hover,
.sidenav li.trigger .modalmenu .ps__rail-y:focus
{
    background-color: #000;
}

.sidenav li.trigger .modalmenu .ps__thumb-y
{
    background-color: #000;
}

.sidenav li.trigger .modalmenu .ps__rail-y:hover > .ps__thumb-y,
.sidenav li.trigger .modalmenu .ps__rail-y:focus > .ps__thumb-y
{
    background-color: #000;
}

.sidenav li.trigger .modalmenu > .inner
{
    padding: 49px 40px 40px;
}

.sidenav li.trigger .modalmenu .subnav-taglist
{
    width: 410px;
    margin-right: -10px;

    list-style: none;
}

.sidenav li.trigger .modalmenu .subnav-taglist:after
{
    display: table;
    clear: both;

    content: '';
}

.sidenav li.trigger .modalmenu .subnav-taglist li
{
    padding: 0;
}

.sidenav li.trigger .modalmenu .subnav-taglist li a
{
    line-height: 1.5;

    display: block;
    float: left;

    width: 195px;
    margin-right: 10px;
    margin-bottom: 10px;
    padding: 6px 20px;

    transition: all .3s ease;
    text-align: center;

    color: #222;
    border-radius: 3px;
    background: #fff;
}

.sidenav li.trigger .modalmenu .subnav-taglist li a.wide
{
    width: 400px;
}

.sidenav li.trigger .modalmenu .subnav-taglist li a:hover
{
    color: #fff;
    background: #6f6f6f;
}

.sidenav li.trigger .modalmenu .subnav-checklist
{
    margin-top: -15px;
}

.sidenav li.trigger .modalmenu .subnav-checklist li
{
    padding: 10px 0;

    color: #fff;
}

/*
.sidenav li.trigger .modalmenu .subnav-checklist li:hover
{
    color: #fb755e;
}
*/

.sidenav li.trigger .modalmenu .subnav-checklist li input[type='checkbox']:checked + label:after
{
    top: 12px;
}

.sidenav li.trigger .modalmenu .subnav-selectlist
{
    margin-top: 30px;
}

.sidenav li.trigger .modalmenu .subnav-selectlist:after
{
    display: table;
    clear: both;

    content: '';
}

.sidenav li.trigger .modalmenu .subnav-selectlist select
{
    display: inline-block;

    min-width: 95px;
    margin-right: 7px;

    transition: all .3s ease;

    color: #222;
    border-color: #222;
    background: #fff url(../img/img_select_sidenav.png) no-repeat right center;
}

.sidenav li.trigger .modalmenu .subnav-selectlist select:hover
{
    border-color: #f1eee6;
    background-color: #f1eee6;
}

.sidenav li.trigger .modalmenu .subnav-selectlist select#years
{
    min-width: 110px;
}

.sidenav li.trigger #subnav-catalogue .btn
{
    display: block;

    width: 130px;
    margin: 50px auto 0;
}

.sidenav li.trigger .modalmenu.active
{
    max-height: 9999px;

    opacity: 1;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
}

/** add **/

#subnav-catalogue .inner,
#subnav-catalogue .subnav-checklist ul,
#subnav-catalogue .subnav-checklist li {
    cursor: default;
}

#subnav-catalogue .subnav-checklist li:hover {
   color:#fff;
}

/** **/

/* ログアウト時 */
#globalnav .nav-pal,
#globalnav .nav-logout
{
    display: none;
}

/* ログイン時 */
body.login #globalnav .nav-login
{
    display: none;
}

body.login #globalnav .nav-pal,
body.login #globalnav .nav-logout
{
    display: block;
}

/* ====================================================
Pagetop
==================================================== */
#pagetop
{
    position: fixed;
    z-index: 100;
    right: 10px;
    bottom: 10px;

    width: 43px;
    height: 60px;

    transition: all .5s ease;

    opacity: 0;
    background: url(../img/ico_pagetop.png) no-repeat 0 0;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=0)';
}

#pagetop.active
{
    opacity: 1;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
}

#pagetop.active:hover
{
    opacity: .6;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=60)';
}

#pagetop.active:active
{
    opacity: .6;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=60)';
}

/* ====================================================
perfect scrollbar
==================================================== */
/*
* Container style
*/
.ps
{
    overflow: hidden !important;

    overflow-anchor: none;
    -ms-overflow-style: none;
        touch-action: auto;
    -ms-touch-action: auto;
}

/*
* Scrollbar rail styles
*/
.ps__rail-x
{
    /* please don't change 'position' */
    position: absolute;
    /* there must be 'bottom' or 'top' for ps__rail-x */
    bottom: 2px;

    display: none;

    height: 3px;

    -webkit-transition: background-color .2s linear, opacity .2s linear;
            transition: background-color .2s linear, opacity .2s linear;

    opacity: 0;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=0)';
}

.ps__rail-y
{
    /* please don't change 'position' */
    position: absolute;
    /* there must be 'right' or 'left' for ps__rail-y */
    right: 2px;

    display: none;

    width: 3px;

    -webkit-transition: background-color .2s linear, opacity .2s linear;
            transition: background-color .2s linear, opacity .2s linear;

    opacity: 0;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=0)';
}

.ps--active-x > .ps__rail-x,
.ps--active-y > .ps__rail-y
{
    display: block;

    background-color: transparent;
}

.ps:hover > .ps__rail-x,
.ps:hover > .ps__rail-y,
.ps--focus > .ps__rail-x,
.ps--focus > .ps__rail-y,
.ps--scrolling-x > .ps__rail-x,
.ps--scrolling-y > .ps__rail-y
{
    opacity: .6;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=60)';
}

/*
* Scrollbar thumb styles
*/
.ps__thumb-x
{
    /* please don't change 'position' */
    position: absolute;
    /* there must be 'bottom' for ps__thumb-x */
    bottom: 0;

    height: 3px;

    -webkit-transition: background-color .2s linear, height .2s ease-in-out;
            transition: background-color .2s linear, height .2s ease-in-out;

    border-radius: 0;
    background-color: #d0cdc4;
}

.ps__thumb-y
{
    /* please don't change 'position' */
    position: absolute;
    /* there must be 'right' for ps__thumb-y */
    right: 0;

    width: 3px;

    -webkit-transition: background-color .2s linear, width .2s ease-in-out;
            transition: background-color .2s linear, width .2s ease-in-out;

    border-radius: 0;
    background-color: #d0cdc4;
}

.ps__rail-x:hover > .ps__thumb-x,
.ps__rail-x:focus > .ps__thumb-x
{
    height: 3px;

    background-color: #a39d8b;
}

.ps__rail-y:hover > .ps__thumb-y,
.ps__rail-y:focus > .ps__thumb-y
{
    width: 3px;

    background-color: #a39d8b;
}

/* MS supports */
@supports (-ms-overflow-style: none)
{
    .ps
    {
        overflow: auto !important;
    }
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none)
{
    .ps
    {
        overflow: auto !important;
    }
}

/* 追加 */
.ps-hide .ps:hover > .ps__rail-x,
.ps-hide .ps:hover > .ps__rail-y,
.ps-hide .ps--focus > .ps__rail-x,
.ps-hide .ps--focus > .ps__rail-y,
.ps-hide .ps--scrolling-x > .ps__rail-x,
.ps-hide .ps--scrolling-y > .ps__rail-y
{
    opacity: 0;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=0)';
}

.ps-hide .ps__rail-x:hover,
.ps-hide .ps__rail-y:hover,
.ps-hide .ps__rail-x:focus,
.ps-hide .ps__rail-y:focus
{
    opacity: 0;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=0)';
}

.ps__rail-x:hover,
.ps__rail-y:hover,
.ps__rail-x:focus,
.ps__rail-y:focus
{
    opacity: .9;
    background-color: #fdfdfd;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=90)';
}

@media print
{
    /* ====================================================
  印刷用レイアウト調整
  ==================================================== */
    body
    {
        zoom: .8;
    }
    .wrap
    {
        padding: 0 20px;
    }
}

/* ====================================================
Utilities
==================================================== */
/* ------------------------
Clearfix
------------------------ */
.clearfix:after
{
    display: table;
    clear: both;

    content: '';
}

/* ------------------------
List
------------------------ */
ul.list,
ol.list
{
    margin-left: 22px;
}

ul.list
{
    list-style: square;
}

ol.list
{
    list-style: decimal;
}

/* ------------------------
Image
------------------------ */
.fitimg
{
    font-family: 'object-fit: cover;';

    object-fit: cover;
}

/* ------------------------
Table
------------------------ */
.dl-table
{
    display: talbe;
}

.dl-table dl
{
    display: table-row;
}

.dl-table dt,
.dl-table dd
{
    display: table-cell;

    vertical-align: top;
}

.table th,
.table td
{
    font-weight: normal;

    padding: 15px 0;
}

/* ------------------------
Label
------------------------ */
.label
{
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1;

    display: inline-block;

    margin-left: 10px;
    padding: 4px 8px 5px;

    color: #fff;
    border-radius: 3px;
    background: #000;
}

/* ------------------------
Badge
------------------------ */
.badge
{
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 20px;

    position: relative;
    top: -2px;

    display: inline-block;

    width: 19px;
    height: 19px;
    margin: 0 .2em;

    text-align: center;

    color: #fff;
}

.badge.badge-a
{
    background: #d44830;
}

.badge.badge-b
{
    background: #305fac;
}

.badge.badge-c
{
    background: #3d9a25;
}

/* ------------------------
Hover
------------------------ */
.txtover
{
    transition: color .3s ease;
}

.txtover:hover
{
    color: #d44830;
}

.imgover a,
a.imgover
{
    transition: opacity .3s ease;

    opacity: 1.0;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=100)';
}

.imgover a:hover,
a.imgover:hover
{
    opacity: .6;

    -ms-filter: 'progid:DXImageTransform.Microsoft.Alpha(Opacity=60)';
}

.btnover a,
a.btnover,
button.btnover
{
    transition: all .3s ease;
}

.btnover a:hover,
a.btnover:hover,
button.btnover:hover
{
    text-decoration: none;

    color: #fff;
    background-color: #222;
}

/* ------------------------
Border
------------------------ */
.border-white
{
    border: 1px solid #fff;
}

.border
{
    border: 1px solid #222;
}

/* ------------------------
非表示
------------------------ */
.hide
{
    display: none !important;
}

/* テキスト非表示 */
.hide-text
{
    font: 0/0 a;

    color: transparent;
    border: 0;
    background-color: transparent;
    text-shadow: none;
}

/* テキスト非表示: スクリーンリーダー専用 */
.sr-only
{
    position: absolute;

    overflow: hidden;
    clip: rect(0, 0, 0, 0);

    width: 1px;
    height: 1px;
    padding: 0;

    white-space: nowrap;

    border: 0;

    -webkit-clip-path: inset(50%);
            clip-path: inset(50%);
}

.sr-only-focusable:active,
.sr-only-focusable:focus
{
    position: static;

    overflow: visible;
    clip: auto;

    width: auto;
    height: auto;

    white-space: normal;

    -webkit-clip-path: none;
            clip-path: none;
}

/* ------------------------
SNSボタン
------------------------ */
/* ------------------------
Media (Google map, You tube etc)
------------------------ */
.media
{
    position: relative;

    overflow: hidden;

    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
}

.media iframe
{
    position: absolute;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;
}

/* ---------------------------
Layout Parts
--------------------------- */
/* Text Alight */
.text-left
{
    text-align: left !important;
}

.text-right
{
    text-align: right !important;
}

.text-center
{
    text-align: center !important;
}

.text-justify
{
    text-align: justify !important;
}

/* Font Weight */
.fw-bold
{
    font-weight: bold !important;
}

.fw-normal
{
    font-weight: normal !important;
}

/* Fixed */
.fixed
{
    position: fixed !important;

    width: 100%;
    height: 100%;
}

.block
{
    display: block !important;
}

/* Float */
.f-left
{
    float: left !important;
}

.f-right
{
    float: right !important;
}

/* Margin */
.m-auto
{
    margin-right: auto !important;
    margin-left: auto !important;
}

.mtop0
{
    margin-top: 0 !important;
}

.mtop5
{
    margin-top: 5px !important;
}

.mtop10
{
    margin-top: 10px !important;
}

.mtop15
{
    margin-top: 15px !important;
}

.mtop20
{
    margin-top: 20px !important;
}

.mtop30
{
    margin-top: 30px !important;
}

.mtop40
{
    margin-top: 40px !important;
}

.mtop50
{
    margin-top: 50px !important;
}

.mtop60
{
    margin-top: 60px !important;
}

.mbtm0
{
    margin-bottom: 0 !important;
}

.mbtm5
{
    margin-bottom: 5px !important;
}

.mbtm10
{
    margin-bottom: 10px !important;
}

.mbtm15
{
    margin-bottom: 15px !important;
}

.mbtm20
{
    margin-bottom: 20px !important;
}

.mbtm30
{
    margin-bottom: 30px !important;
}

.mbtm40
{
    margin-bottom: 40px !important;
}

.mbtm50
{
    margin-bottom: 50px !important;
}

.mbtm60
{
    margin-bottom: 60px !important;
}

/* Padding */
.ptop0
{
    padding-top: 0 !important;
}

.ptop5
{
    padding-top: 5px !important;
}

.ptop10
{
    padding-top: 10px !important;
}

.ptop15
{
    padding-top: 15px !important;
}

.ptop20
{
    padding-top: 20px !important;
}

.ptop30
{
    padding-top: 30px !important;
}

.ptop40
{
    padding-top: 40px !important;
}

.ptop50
{
    padding-top: 50px !important;
}

.ptop60
{
    padding-top: 60px !important;
}

.pbtm0
{
    padding-bottom: 0 !important;
}

.pbtm5
{
    padding-bottom: 5px !important;
}

.pbtm10
{
    padding-bottom: 10px !important;
}

.pbtm15
{
    padding-bottom: 15px !important;
}

.pbtm20
{
    padding-bottom: 20px !important;
}

.pbtm30
{
    padding-bottom: 30px !important;
}

.pbtm40
{
    padding-bottom: 40px !important;
}

.pbtm50
{
    padding-bottom: 50px !important;
}

.pbtm60
{
    padding-bottom: 60px !important;
}

/* Width */
.w5
{
    width: 5% !important;
}

.w10
{
    width: 10% !important;
}

.w15
{
    width: 15% !important;
}

.w20
{
    width: 20% !important;
}

.w25
{
    width: 25% !important;
}

.w30
{
    width: 30% !important;
}

.w35
{
    width: 35% !important;
}

.w40
{
    width: 40% !important;
}

.w45
{
    width: 45% !important;
}

.w50
{
    width: 50% !important;
}

.w55
{
    width: 55% !important;
}

.w60
{
    width: 60% !important;
}

.w65
{
    width: 65% !important;
}

.w70
{
    width: 70% !important;
}

.w75
{
    width: 75% !important;
}

.w80
{
    width: 80% !important;
}

.w85
{
    width: 85% !important;
}

.w90
{
    width: 90% !important;
}

.w95
{
    width: 95% !important;
}

.w100
{
    width: 100% !important;
}
