@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP&subset=japanese");
@import url("../vendor/esk-icon/css/esk-icon.css");
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

body {
    line-height: 1;
}

ol,
ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

html {
    background: #faf8eb;
    color: #000;
    font-family: メイリオ, Meiryo, "ヒラギノ角ゴ Pro W3", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", YuGothic, "ＭＳ Ｐゴシック", sans-serif;
}

@media only screen and (min-width: 769px) {
    html {
        font-size: 16px;
    }
}

@media only screen and (max-width: 768px) {
    html {
        font-size: 3.90625vw;
    }
}

@media only screen and (min-width: 769px) {
    body {
        padding-top: 135px;
    }
}

@media only screen and (max-width: 768px) {
    body {
        padding-top: 53px;
    }
}

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

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

a {
    color: #0098e7;
    outline: 0;
}

a:not([class]) {
    text-decoration: none;
}

a:not([class]):hover {
    text-decoration: underline;
}

sup {
    font-size: 70%;
    vertical-align: top;
}

.lay-header {
    background-color: #fff;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 10;
}

@media only screen and (min-width: 769px) {
    .lay-header {
        padding-top: 28px;
        border-bottom: 3px solid #8dc21f;
    }
}

@media only screen and (max-width: 768px) {
    .lay-header {
        border-bottom: 2px solid #8dc21f;
    }
}

.lay-header_wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

@media only screen and (min-width: 769px) {
    .lay-header_wrap {
        width: 1100px;
        padding-left: 10px;
        padding-right: 10px;
        margin: 0 auto;
    }
}

@media only screen and (max-width: 768px) {
    .lay-header_wrap {
        padding: 8px;
        position: relative;
    }
}

.lay-header_anchor {
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

.lay-header_anchor:hover {
    opacity: 0.7;
}

@media only screen and (max-width: 768px) {
    .lay-header_anchor img {
        height: 33px;
    }
}

.lay-header_btns {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

@media only screen and (max-width: 768px) {
    .lay-header_btns {
        display: none;
        padding: 3.90625vw;
        overflow: hidden;
    }
}

.lay-header_back {
    text-decoration: none;
    font-weight: bold;
    color: #898989;
}

@media only screen and (min-width: 769px) {
    .lay-header_back {
        font-size: 14px;
        margin-right: 30px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-header_back {
        display: block;
        text-align: center;
        width: 100%;
        margin-top: 2.60417vw;
        margin-bottom: 5.20833vw;
    }
}

.lay-header_back:hover {
    text-decoration: underline;
}

.lay-header_btn {
    color: #fff;
    text-decoration: none;
    border-radius: 5px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (min-width: 769px) {
    .lay-header_btn {
        padding: 10px 20px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-header_btn {
        width: 46%;
        padding: 2.60417vw 2.60417vw;
        text-align: center;
    }
    .lay-header_btn:nth-child(1) {
        float: left;
    }
    .lay-header_btn:nth-child(2) {
        float: right;
    }
}

@media only screen and (min-width: 769px) {
    .lay-header_btn+.lay-header_btn {
        margin-left: 10px;
    }
}

.lay-header_btn:hover {
    opacity: 0.7;
}

.lay-header_btn.icon-esk-login {
    background-color: #edbc1f;
}

.lay-header_btn.icon-esk-login::before {
    vertical-align: text-top;
}

@media only screen and (min-width: 769px) {
    .lay-header_btn.icon-esk-login::before {
        font-size: 20px;
        margin-right: 5px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-header_btn.icon-esk-login::before {
        font-size: 4.16667vw;
        vertical-align: -6%;
    }
}

.lay-header_btn.icon-esk-star {
    background-color: #8dc21f;
}

.lay-header_btn.icon-esk-star::before {
    vertical-align: text-top;
}

@media only screen and (min-width: 769px) {
    .lay-header_btn.icon-esk-star::before {
        font-size: 20px;
        margin-right: 5px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-header_btn.icon-esk-star::before {
        font-size: 4.16667vw;
        vertical-align: -6%;
    }
}

@media only screen and (max-width: 768px) {
    .lay-nav {
        display: none;
    }
}

@media only screen and (min-width: 769px) {
    .lay-nav_list {
        width: 1100px;
        padding-left: 10px;
        padding-right: 10px;
        margin: 0 auto;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
    }
}

.lay-nav_anchor {
    display: block;
    font-weight: bold;
    color: #88653b;
    text-decoration: none;
}

@media only screen and (min-width: 769px) {
    .lay-nav_anchor {
        padding: 0 20px;
        font-size: 16px;
        height: 62px;
        line-height: 62px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-nav_anchor {
        text-align: center;
        padding: 3.90625vw;
    }
}

.lay-nav_anchor.icon-esk-home {
    color: #8dc21f;
}

@media only screen and (min-width: 769px) {
    .lay-nav_anchor.icon-esk-home {
        font-size: 24px;
        padding: 0 15px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-nav_anchor.icon-esk-home {
        padding: 1.95313vw 3.90625vw;
    }
}

@media only screen and (min-width: 769px) {
    .lay-footer {
        padding-top: 50px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-footer {
        padding-top: 10.41667vw;
    }
}

@media only screen and (min-width: 769px) {
    .lay-footer_band {
        height: 270px;
        background: transparent url("../media/footer_bg.png") repeat-x left top;
        background-size: auto 270px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-footer_band {
        height: 26.04167vw;
        background: transparent url("../media/footer_bg.png") repeat-x left top;
        background-size: auto 26.04167vw;
    }
}

@media only screen and (min-width: 769px) {
    .lay-footer_wrap {
        width: 1100px;
        padding-left: 10px;
        padding-right: 10px;
        margin: 0 auto;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }
}

@media only screen and (max-width: 768px) {
    .lay-footer_wrap {
        padding-left: 3.90625vw;
        padding-right: 3.90625vw;
    }
}

.lay-footer_anchor {
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (max-width: 768px) {
    .lay-footer_anchor {
        display: block;
        margin-bottom: 6.51042vw;
    }
}

.lay-footer_anchor:hover {
    opacity: 0.7;
}

.lay-footer_btns {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}

@media only screen and (max-width: 768px) {
    .lay-footer_btns {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }
}

.lay-footer_btn {
    color: #fff;
    text-decoration: none;
    border-radius: 5px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (min-width: 769px) {
    .lay-footer_btn {
        padding: 10px 20px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-footer_btn {
        padding: 2.60417vw 2.60417vw;
        width: 48%;
        text-align: center;
    }
}

.lay-footer_btn:hover {
    opacity: 0.7;
}

@media only screen and (min-width: 769px) {
    .lay-footer_btn+.lay-footer_btn {
        margin-left: 10px;
    }
}

.lay-footer_btn.icon-esk-login {
    background-color: #edbc1f;
}

.lay-footer_btn.icon-esk-login::before {
    vertical-align: text-top;
}

@media only screen and (min-width: 769px) {
    .lay-footer_btn.icon-esk-login::before {
        font-size: 20px;
        margin-right: 5px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-footer_btn.icon-esk-login::before {
        font-size: 4.16667vw;
        vertical-align: -6%;
    }
}

.lay-footer_btn.icon-esk-star {
    background-color: #8dc21f;
}

.lay-footer_btn.icon-esk-star::before {
    vertical-align: text-top;
}

@media only screen and (min-width: 769px) {
    .lay-footer_btn.icon-esk-star::before {
        font-size: 20px;
        margin-right: 5px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-footer_btn.icon-esk-star::before {
        font-size: 4.16667vw;
        vertical-align: -6%;
    }
}

@media only screen and (min-width: 769px) {
    .lay-footerNav_list {
        width: 1100px;
        padding-left: 10px;
        padding-right: 10px;
        margin: 0 auto;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
    }
}

@media only screen and (max-width: 768px) {
    .lay-footerNav_list {
        margin-top: 3.90625vw;
        margin-bottom: 3.90625vw;
    }
}

.lay-footerNav_anchor {
    display: block;
    font-weight: bold;
    color: #88653b;
    text-decoration: none;
}

@media only screen and (min-width: 769px) {
    .lay-footerNav_anchor {
        padding: 0 20px;
        font-size: 16px;
        height: 80px;
        line-height: 80px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-footerNav_anchor {
        display: block;
        text-align: center;
        padding: 2.60417vw;
    }
}

@media only screen and (min-width: 769px) {
    .lay-footerNav_anchor.icon-esk-home {
        font-size: 24px;
        padding: 0 15px;
    }
}

.lay-footer_copy {
    color: #88653b;
    display: block;
    text-align: center;
}

@media only screen and (min-width: 769px) {
    .lay-footer_copy {
        font-size: 12px;
        padding-top: 10px;
        padding-bottom: 40px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-footer_copy {
        font-size: 3.125vw;
        line-height: 1.5;
        padding-top: 1.30208vw;
        padding-bottom: 5.20833vw;
    }
}

@media only screen and (min-width: 769px) {
    .lay-header_navsSP {
        display: none;
    }
}

@media only screen and (max-width: 768px) {
    .lay-header_navsSP {
        position: relative;
        z-index: 3;
    }
}

@media only screen and (max-width: 768px) {
    .lay-header_navsSP .lay-header_btns {
        display: block;
    }
}

.lay-header_menuSP,
.lay-header_menuSP span {
    display: inline-block;
    -webkit-transition: all .3s;
    -o-transition: all .3s;
    transition: all .3s;
    -webkit-transition-delay: 0;
    -o-transition-delay: 0;
    transition-delay: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.lay-header_menuSP {
    position: absolute;
    right: 42px;
    width: 35px;
    height: 35px;
    background-color: #a8855c;
    border-radius: 3px;
}

.lay-header_menuSP span {
    position: absolute;
    left: 7px;
    width: 20px;
    height: 3px;
    background-color: #fff;
    border-radius: 4px;
}

.lay-header_menuSP span:nth-of-type(1) {
    top: 10px;
}

.lay-header_menuSP span:nth-of-type(2) {
    top: 16px;
}

.lay-header_menuSP span:nth-of-type(3) {
    top: 22px;
}

.lay-header_menuSP.active span:nth-of-type(1) {
    -webkit-transform: translateY(6px) rotate(-45deg);
    -ms-transform: translateY(6px) rotate(-45deg);
    transform: translateY(6px) rotate(-45deg);
}

.lay-header_menuSP.active span:nth-of-type(2) {
    opacity: 0;
}

.lay-header_menuSP.active span:nth-of-type(3) {
    -webkit-transform: translateY(-6px) rotate(45deg);
    -ms-transform: translateY(-6px) rotate(45deg);
    transform: translateY(-6px) rotate(45deg);
}

.lay-header_menuSP.active {
    right: 0;
    z-index: 5;
    background-color: #886b49;
}

.lay-header_navSP {
    display: none;
    background-color: #fff;
    -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
    box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
}

.lay-header_navSP.active {
    display: block;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
}

@media only screen and (max-width: 768px) {
    .lay-header_navSP.active {
        border-top: 53px solid #886b49;
    }
}

.lay-header_navSP_list {
    background-color: #cf2b3f;
    padding-top: 48px;
}

.lay-header_navSP_item {
    background-color: #ff3850;
}

.lay-header_navSP_item+.lay-header_navSP_item {
    border-top: 1px solid #ff6b7d;
}

.lay-header_navSP_anchor {
    color: #fff;
    display: block;
    text-align: center;
    padding: 20px 0;
    font-weight: bold;
    text-decoration: none;
    font-size: 14px;
}

.lay-header_userSP_name {
    display: block;
    position: relative;
    width: 35px;
    height: 35px;
    background-color: #edbc1f;
    border-radius: 3px;
    color: #fff;
    line-height: 40px;
    text-align: center;
    font-size: 22px;
    text-decoration: none;
}

.lay-header_userSP_name:hover {
    background-color: #c99d10;
}

@media only screen and (min-width: 769px) {
    .lay-breadcrumb {
        padding: 25px 0;
    }
}

@media only screen and (max-width: 768px) {
    .lay-breadcrumb {
        padding: 5.20833vw 0;
    }
}

.lay-breadcrumb_item {
    display: inline-block;
    color: #a8855c;
    line-height: 1.6;
}

@media only screen and (min-width: 769px) {
    .lay-breadcrumb_item {
        font-size: 13px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-breadcrumb_item {
        font-size: 3.125vw;
    }
}

.lay-breadcrumb_item+.lay-breadcrumb_item::before {
    content: ">";
    display: inline-block;
}

@media only screen and (min-width: 769px) {
    .lay-breadcrumb_item+.lay-breadcrumb_item::before {
        margin-left: 10px;
        margin-right: 10px;
    }
}

@media only screen and (max-width: 768px) {
    .lay-breadcrumb_item+.lay-breadcrumb_item::before {
        margin-left: 1.30208vw;
        margin-right: 1.30208vw;
    }
}

.lay-breadcrumb_anchor {
    color: #a8855c;
    text-decoration: none;
}

.lay-breadcrumb_anchor:hover {
    text-decoration: underline;
}

@media only screen and (min-width: 769px) {
    .mod-container {
        width: 1100px;
        padding-left: 10px;
        padding-right: 10px;
        margin: 0 auto;
    }
}

@media only screen and (max-width: 768px) {
    .mod-container {
        padding-left: 3.90625vw;
        padding-right: 3.90625vw;
    }
}

@media only screen and (min-width: 769px) {
    .mod-wrap {
        width: 800px;
        margin: 0 auto;
    }
}

.mod-card {
    -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
    box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
    background-color: #fff;
}

@media only screen and (min-width: 769px) {
    .mod-card {
        padding: 80px 140px;
        margin-top: 45px;
        margin-bottom: 45px;
        border-radius: 10px;
    }
}

@media only screen and (max-width: 768px) {
    .mod-card {
        padding: 10.41667vw 7.8125vw;
        margin-top: 10.41667vw;
        margin-bottom: 10.41667vw;
        border: 1px solid #f1f1f1;
        margin-left: -3.90625vw;
        margin-right: -3.90625vw;
    }
}

.mod-card>*:first-child {
    margin-top: 0;
}

.mod-card>*:last-child {
    margin-bottom: 0;
}

@media only screen and (max-width: 768px) {
    .mod-card.mod-card-mb0Sp {
        margin-bottom: 0;
    }
}

@media only screen and (min-width: 769px) {
    .mod-card-small {
        padding: 60px;
        margin-top: 30px;
        margin-bottom: 30px;
        border-radius: 10px;
    }
}

@media only screen and (max-width: 768px) {
    .mod-card-small {
        padding: 10.41667vw 6.51042vw;
        margin-top: 2.60417vw;
        margin-bottom: 7.8125vw;
    }
}

.mod-btns {
    text-align: center;
}

@media only screen and (min-width: 769px) {
    .mod-btns {
        margin: 40px 0;
    }
}

@media only screen and (max-width: 768px) {
    .mod-btns {
        margin: 9.11458vw 0;
    }
}

.mod-btn {
    display: inline-block;
    font-weight: bold;
    text-align: center;
    border-radius: 10px;
    background-color: #ffb400;
    text-decoration: none;
    color: #fff;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (min-width: 769px) {
    .mod-btn {
        font-size: 22px;
        padding: 20px 60px;
    }
}

@media only screen and (max-width: 768px) {
    .mod-btn {
        font-size: 4.16667vw;
        padding: 5.20833vw 15.625vw;
    }
}

.mod-btn:hover {
    opacity: 0.7;
}

.mod-tag {
    background-color: #8dc21f;
    color: #fff;
    font-weight: bold;
    display: inline-block;
    padding: 0.5rem 1.5rem 0.5rem 1.2rem;
    border-radius: 5px;
}

@media only screen and (min-width: 769px) {
    .mod-tag {
        margin-bottom: 20px;
    }
}

@media only screen and (max-width: 768px) {
    .mod-tag {
        margin-bottom: 2.60417vw;
    }
}

.top-title {
    text-align: center;
}

@media only screen and (min-width: 769px) {
    .top-title_bg {
        height: 420px;
        background: url("../media/keyvisual_e.png") no-repeat center top;
        background-size: cover;
    }
}

@media only screen and (max-width: 768px) {
    .top-title_bg {
        height: 74.21875vw;
        background: url("../media/keyvisual_e-sp.png") no-repeat center top;
        background-size: 100%;
    }
}

.top-title_logo {
    display: inline-block;
}

@media only screen and (min-width: 769px) {
    .top-title_logo {
        padding: 50px 0;
    }
}

@media only screen and (max-width: 768px) {
    .top-title_logo {
        padding-left: 3.90625vw;
        padding-right: 3.90625vw;
        padding-bottom: 7.8125vw;
    }
}

.top-newbooks_latest {
    background-color: #fff;
    -webkit-box-shadow: 2px 2px 5px 2px rgba(175, 171, 143, 0.15);
    box-shadow: 2px 2px 5px 2px rgba(175, 171, 143, 0.15);
    border-radius: 5px;
}

@media only screen and (min-width: 769px) {
    .top-newbooks_latest {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        padding: 30px 60px;
    }
}

@media only screen and (max-width: 768px) {
    .top-newbooks_latest {
        padding: 6.51042vw;
    }
}

.top-newbooks_latest_title {
    font-weight: bold;
    color: #404040;
}

@media only screen and (min-width: 769px) {
    .top-newbooks_latest_title {
        font-size: 16px;
        width: 130px;
    }
}

@media only screen and (max-width: 768px) {
    .top-newbooks_latest_title {
        font-size: 4.16667vw;
        text-align: center;
    }
}

.top-newbooks_latest_title_icon {
    color: #8dc21f;
}

@media only screen and (min-width: 769px) {
    .top-newbooks_latest_title_icon {
        font-size: 43px;
        margin-bottom: 10px;
    }
}

@media only screen and (max-width: 768px) {
    .top-newbooks_latest_title_icon {
        font-size: 11.71875vw;
        margin-bottom: 1.95313vw;
    }
}

@media only screen and (min-width: 769px) {
    .top-newbooks_latest_list {
        -webkit-box-flex: 1;
        -webkit-flex: 1;
        -ms-flex: 1;
        flex: 1;
    }
}

@media only screen and (max-width: 768px) {
    .top-newbooks_latest_list {
        margin-top: 5.20833vw;
    }
}

.top-newbooks_latest_item {
    line-height: 1.8;
}

@media only screen and (min-width: 769px) {
    .top-newbooks_latest_item {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
    }
}

@media only screen and (max-width: 768px) {
    .top-newbooks_latest_item {
        margin-top: 3.90625vw;
    }
}

@media only screen and (min-width: 769px) {
    .top-newbooks_latest_item+.top-newbooks_latest_item {
        margin-top: 5px;
    }
}

.top-newbooks_latest_item_time {
    color: #ff892a;
}

@media only screen and (min-width: 769px) {
    .top-newbooks_latest_item_time {
        margin-right: 25px;
    }
}

@media only screen and (min-width: 769px) {
    .page-heading {
        margin-bottom: 45px;
        text-align: center;
    }
}

@media only screen and (max-width: 768px) {
    .page-heading {
        margin-bottom: 7.8125vw;
    }
}

.page-menu {
    background-color: #fff;
}

@media only screen and (min-width: 769px) {
    .page-menu {
        padding: 35px 0;
        margin-top: 80px;
    }
}

@media only screen and (max-width: 768px) {
    .page-menu {
        padding: 0vw 0;
        margin-top: 10.41667vw;
    }
}

@media only screen and (min-width: 769px) {
    .page-menu_wrap {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
    }
}

@media only screen and (max-width: 768px) {
    .page-menu_wrap {
        padding: 0 3.90625vw;
    }
}

.page-menu_item {
    display: block;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (max-width: 768px) {
    .page-menu_item {
        padding: 0vw 0;
    }
}

@media only screen and (min-width: 769px) {
    .page-menu_item+.page-menu_item {
        border-left: 1px solid #d5d5d5;
    }
}

@media only screen and (max-width: 768px) {
    .page-menu_item+.page-menu_item {
        border-top: 1px solid #d5d5d5;
    }
}

.page-menu_item:hover {
    opacity: 0.7;
}

@media only screen and (min-width: 769px) {
    .top-nav {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
        justify-content: space-between;
        margin: 50px 0;
    }
}

.top-nav_item {
    background-color: #fff;
    border-radius: 10px;
    display: block;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (max-width: 768px) {
    .top-nav_item {
        margin: 6.51042vw 0;
    }
}

.top-nav_item:hover {
    opacity: 0.9;
}

.term-order {
    font-weight: bold;
}

@media only screen and (min-width: 769px) {
    .term-order {
        font-size: 18px;
    }
}

@media only screen and (max-width: 768px) {
    .term-order {
        font-size: 4.16667vw;
    }
}

.term-title {
    font-weight: bold;
    border-bottom: 2px solid #ffc91e;
    text-indent: -1em;
    padding-left: 1em;
    line-height: 1.6;
    word-break: break-all;
}

@media only screen and (min-width: 769px) {
    .term-title {
        font-size: 20px;
        padding-bottom: 10px;
        margin-top: 50px;
        margin-bottom: 20px;
    }
}

@media only screen and (max-width: 768px) {
    .term-title {
        font-size: 4.16667vw;
        padding-bottom: 2.60417vw;
        margin-top: 6.51042vw;
        margin-bottom: 2.60417vw;
    }
}

.term-title span {
    color: #ffc91e;
}

.term-p a {
    text-decoration: underline;
}

.term-p a:hover {
    text-decoration: none;
}

.page-lead {
    color: #6c4e31;
    line-height: 1.8;
    font-weight: bold;
    text-align: center;
}

@media only screen and (min-width: 769px) {
    .page-lead {
        font-size: 18px;
        margin-top: -20px;
    }
}

@media only screen and (min-width: 769px) {
    .series-card {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        margin-top: 50px;
    }
}

@media only screen and (max-width: 768px) {
    .series-card {
        margin-top: 7.8125vw;
    }
}

.series-card_item {
    display: block;
    background-color: #fff;
    border-radius: 10px;
    color: #000;
    text-decoration: none;
    -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
    box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (min-width: 769px) {
    .series-card_item {
        width: 340px;
        margin-bottom: 30px;
        margin-left: 30px;
    }
}

@media only screen and (max-width: 768px) {
    .series-card_item {
        margin-bottom: 6.51042vw;
    }
}

@media only screen and (min-width: 769px) {
    .series-card_item:nth-child(3n+1) {
        margin-left: 0;
    }
}

.series-card_item:hover {
    opacity: 0.7;
}

.series-card_body {
    font-weight: bold;
    line-height: 1.4;
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

@media only screen and (min-width: 769px) {
    .series-card_body_wrap {
        padding: 15px 70px 15px 30px;
    }
}

@media only screen and (max-width: 768px) {
    .series-card_body_wrap {
        padding: 5.20833vw 9.11458vw 5.20833vw 3.90625vw;
    }
}

@media only screen and (min-width: 769px) {
    .series-card_body_title {
        font-size: 14px;
    }
}

@media only screen and (max-width: 768px) {
    .series-card_body_title {
        font-size: 3.64583vw;
    }
}

.series-card_body_sub {
    color: #8dc21f;
}

@media only screen and (min-width: 769px) {
    .series-card_body_sub {
        font-size: 18px;
    }
}

@media only screen and (max-width: 768px) {
    .series-card_body_sub {
        font-size: 4.6875vw;
    }
}

.series-card_arrow {
    background-color: #8dc21f;
    border-radius: 50%;
    text-align: center;
    color: #fff;
    font-weight: bold;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media only screen and (min-width: 769px) {
    .series-card_arrow {
        width: 25px;
        height: 25px;
        line-height: 27px;
        right: 20px;
    }
}

@media only screen and (max-width: 768px) {
    .series-card_arrow {
        width: 6.51042vw;
        height: 6.51042vw;
        line-height: 7.03125vw;
        right: 3.90625vw;
    }
}

.series-detail_heading {
    font-weight: bold;
    line-height: 1.6;
    color: #8dc21f;
}

@media only screen and (min-width: 769px) {
    .series-detail_heading {
        font-size: 34px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_heading {
        font-size: 6.77083vw;
        margin-top: 2.60417vw;
    }
}

.series-detail_lead {
    font-weight: bold;
    line-height: 1.6;
}

@media only screen and (min-width: 769px) {
    .series-detail_lead {
        font-size: 20px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_lead {
        font-size: 4.16667vw;
    }
}

@media only screen and (min-width: 769px) {
    .series-detail_box {
        margin-top: 30px;
        padding-top: 40px;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        border-top: 2px solid #c0b99d;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_box {
        margin-top: 3.90625vw;
    }
}

@media only screen and (min-width: 769px) {
    .series-detail_box_meta {
        width: 313px;
    }
}

@media only screen and (min-width: 769px) {
    .series-detail_box_meta_image {
        margin-bottom: 40px;
    }
}

.series-detail_box_meta_data_heading {
    color: #fff;
    background-color: #c0b99d;
    font-weight: bold;
}

@media only screen and (min-width: 769px) {
    .series-detail_box_meta_data_heading {
        padding: 12px 15px;
        margin-bottom: 15px;
        border-radius: 5px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_box_meta_data_heading {
        padding: 3.125vw 3.90625vw;
        margin-top: 5.20833vw;
        margin-bottom: 1.95313vw;
        border-radius: 1.30208vw;
    }
}

.series-detail_box_meta_data_basic_wrap {
    line-height: 1.8;
}

.series-detail_box_meta_data_basic_term {
    display: inline;
}

.series-detail_box_meta_data_basic_term span {
    color: #ff8042;
}

.series-detail_box_meta_data_basic_value {
    display: inline;
}

.series-detail_box_body {
    line-height: 2;
}

@media only screen and (min-width: 769px) {
    .series-detail_box_body {
        -webkit-box-flex: 1;
        -webkit-flex: 1;
        -ms-flex: 1;
        flex: 1;
        margin-left: 45px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_box_body {
        margin-top: 6.51042vw;
    }
}

.series-detail_box_body p+p {
    margin-top: 1.5rem;
}

@media only screen and (min-width: 769px) {
    .series-detail_ekids {
        padding: 60px 0;
        margin-top: 60px;
        border-top: 2px solid #c0b99d;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_ekids {
        margin-left: -6.51042vw;
        margin-right: -6.51042vw;
    }
}

.series-detail_ekids_box {
    background-color: #fcfbf5;
    border: 1px solid #f1eede;
}

@media only screen and (min-width: 769px) {
    .series-detail_ekids_box {
        padding: 50px 60px;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
        border-radius: 10px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_ekids_box {
        padding: 10.41667vw 6.51042vw 10.41667vw 6.51042vw;
        margin-top: 7.8125vw;
    }
}

.series-detail_ekids_box_text {
    line-height: 1.7;
    font-weight: bold;
}

@media only screen and (min-width: 769px) {
    .series-detail_ekids_box_text {
        -webkit-box-flex: 1;
        -webkit-flex: 1;
        -ms-flex: 1;
        flex: 1;
        padding-left: 60px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_ekids_box_text {
        margin-top: 3.90625vw;
        font-size: 3.64583vw;
        text-align: center;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_sample {
        margin-top: 7.8125vw;
    }
}

@media only screen and (min-width: 769px) {
    .series-detail_sample_item+.series-detail_sample_item {
        margin-top: 50px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_sample_item+.series-detail_sample_item {
        margin-top: 7.8125vw;
    }
}

.series-detail_sample_heading {
    border-top: 2px solid #c0b99d;
    border-bottom: 1px solid #c0b99d;
    font-weight: bold;
}

@media only screen and (min-width: 769px) {
    .series-detail_sample_heading {
        font-size: 22px;
        padding: 20px 0;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_sample_heading {
        font-size: 4.16667vw;
        padding: 2.60417vw 0;
    }
}

.series-detail_sample_dl {
    font-weight: bold;
}

@media only screen and (min-width: 769px) {
    .series-detail_sample_dl {
        margin-top: 15px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_sample_dl {
        margin-top: 3.90625vw;
    }
}

.series-detail_sample_wrap {
    display: inline-block;
}

.series-detail_sample_wrap+.series-detail_sample_wrap {
    margin-left: 1rem;
}

.series-detail_sample_term {
    display: inline;
    color: #ff6600;
}

.series-detail_sample_data {
    display: inline;
}

.series-detail_sample_main {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}

@media only screen and (min-width: 769px) {
    .series-detail_sample_main {
        margin-top: 30px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_sample_main {
        margin-top: 3.90625vw;
    }
}

@media only screen and (min-width: 769px) {
    .series-detail_sample_image {
        width: 130px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_sample_image {
        width: 23.4375vw;
    }
}

.series-detail_sample_body {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1;
    display: flex;
    flex-direction: column;
}

@media only screen and (min-width: 769px) {
    .series-detail_sample_body {
        margin-left: 30px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_sample_body {
        margin-left: 2.60417vw;
    }
}

.series-detail_sample_text {
    line-height: 1.8;
}

@media only screen and (max-width: 768px) {
    .series-detail_sample_text {
        font-size: 3.64583vw;
    }
}

.series-detail_sample_btn {
    background-color: #edbc1f;
    color: #fff;
    font-weight: bold;
    text-decoration: none;
    border-radius: 30px;
    display: inline-block;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
    width: fit-content;
}

@media only screen and (min-width: 769px) {
    .series-detail_sample_btn {
        padding: 10px 30px;
        margin-top: 20px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_sample_btn {
        padding: 1.95313vw 6.51042vw;
        margin-top: 2.60417vw;
        font-size: 3.64583vw;
    }
}

.series-detail_sample_btn:hover {
    opacity: 0.7;
}

.series-detail_sample_btn .icon-esk-book-open {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

@media only screen and (min-width: 769px) {
    .series-detail_sample_btn .icon-esk-book-open::before {
        font-size: 24px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_sample_btn .icon-esk-book-open::before {
        font-size: 5.46875vw;
    }
}

.series-detail_xlsx {
    text-align: center;
    border-top: 2px solid #c0b99d;
}

@media only screen and (min-width: 769px) {
    .series-detail_xlsx {
        font-size: 18px;
        margin-top: 60px;
        padding: 60px 0 30px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_xlsx {
        font-size: 4.16667vw;
        margin-top: 7.8125vw;
        padding: 7.8125vw 0 3.90625vw;
    }
}

.series-detail_xlsx_text {
    font-weight: bold;
}

@media only screen and (max-width: 768px) {
    .series-detail_xlsx_text {
        line-height: 1.6;
    }
}

.series-detail_xlsx_btn {
    background-color: #8dc21f;
    color: #fff;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    border-radius: 25px;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (min-width: 769px) {
    .series-detail_xlsx_btn {
        margin-top: 20px;
        padding: 15px 30px;
    }
}

@media only screen and (max-width: 768px) {
    .series-detail_xlsx_btn {
        margin-top: 5.20833vw;
        padding: 2.60417vw 5.20833vw;
    }
}

.series-detail_xlsx_btn:hover {
    opacity: 0.7;
}

.mod-detail_back {
    text-align: center;
}

@media only screen and (min-width: 769px) {
    .mod-detail_back {
        margin-top: 60px;
    }
}

.mod-detail_back_btn {
    display: inline-block;
    position: relative;
    color: #000;
    font-weight: bold;
    text-decoration: none;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (min-width: 769px) {
    .mod-detail_back_btn {
        font-size: 18px;
    }
}

.mod-detail_back_btn:hover {
    opacity: 0.7;
}

.mod-detail_back_btn::before {
    font-weight: bold;
    display: inline-block;
    margin-right: 10px;
    content: '\e801';
    font-family: "esk-icon";
    color: #8dc21f;
    z-index: 1;
}

@media only screen and (min-width: 769px) {
    .topic-card {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        flex-wrap: wrap;
    }
}

.topic-card_item {
    position: relative;
    display: block;
    background-color: #fff;
    border-radius: 10px;
    color: #000;
    text-decoration: none;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
    flex-wrap: wrap;
}

@media only screen and (min-width: 769px) {
    .topic-card_item {
        width: 340px;
        margin-left: 30px;
        margin-top: 30px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-card_item {
        margin-top: 6.51042vw;
    }
}

.topic-card_item:hover {
    opacity: 0.8;
}

@media only screen and (min-width: 769px) {
    .topic-card_item:nth-child(3n+1) {
        margin-left: 0;
    }
}

.topic-card_item_new {
    position: absolute;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media only screen and (min-width: 769px) {
    .topic-card_item_body {
        padding: 30px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-card_item_body {
        padding: 5.20833vw;
    }
}

.topic-card_item_subTitle {
    line-height: 1.6;
}

.topic-card_item_title {
    font-weight: bold;
    color: #6c4e31;
    line-height: 1.4;
}

@media only screen and (min-width: 769px) {
    .topic-card_item_title {
        font-size: 20px;
        margin: 5px 0;
        line-height: 1.4;
    }
}

@media only screen and (max-width: 768px) {
    .topic-card_item_title {
        font-size: 4.6875vw;
        line-height: 1.6;
    }
}

.topic-card_item_time {
    color: #ff6600;
    line-height: 1.6;
}

@media only screen and (min-width: 769px) {
    .topic-card_item_time {
        font-size: 14px;
    }
}

@media only screen and (min-width: 769px) {
    .topic-detail {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }
}

@media only screen and (min-width: 769px) {
    .topic-detail_main {
        width: 640px;
    }
}

@media only screen and (min-width: 769px) {
    .topic-detail_main_image {
        margin-bottom: 30px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_image {
        margin-bottom: 5.20833vw;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_meta {
        margin-bottom: 1.30208vw;
    }
}

.topic-detail_main_meta_time {
    color: #ff6600;
}

@media only screen and (min-width: 769px) {
    .topic-detail_main_meta_time {
        margin-left: 10px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_meta_time {
        margin-left: 2.60417vw;
    }
}

.topic-detail_main_subTitle {
    line-height: 1.6;
}

@media only screen and (min-width: 769px) {
    .topic-detail_main_subTitle {
        font-size: 20px;
        font-weight: bold;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_subTitle {
        font-size: 4.16667vw;
    }
}

.topic-detail_main_title {
    font-weight: bold;
    line-height: 1.5;
    border-top: 1px solid #c0b99d;
    border-bottom: 1px solid #c0b99d;
    color: #6c4e31;
}

@media only screen and (min-width: 769px) {
    .topic-detail_main_title {
        font-size: 30px;
        margin-bottom: 30px;
        padding: 15px 0;
        margin-top: 20px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_title {
        font-size: 5.46875vw;
        margin-bottom: 5.20833vw;
        padding: 3.90625vw 0;
    }
}

.topic-detail_main_body {
    line-height: 2;
}

.topic-detail_main_body p {
    margin-bottom: 1.5rem;
}

.topic-detail_main_body h2 {
    font-weight: bold;
    color: #6c4e31;
}

@media only screen and (min-width: 769px) {
    .topic-detail_main_body h2 {
        margin: 40px 0 25px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_body h2 {
        margin: 7.8125vw 0 5.20833vw;
    }
}

.topic-detail_main_body h2::before {
    content: "――";
}

.topic-detail_main_body .imageCaption {
    line-height: 1.5;
    margin-top: 1rem;
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_body .imageCaption {
        font-size: 3.64583vw;
    }
}

.topic-detail_main_subheading {
    font-weight: bold;
    border-bottom: 2px solid #ffc91e;
    text-indent: -1em;
    padding-left: 1em;
    line-height: 1.6;
    word-break: break-all;
}

.topic-detail_main_pager {
    border-top: 1px solid #c0b99d;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

@media only screen and (min-width: 769px) {
    .topic-detail_main_pager {
        padding-top: 50px;
        padding-bottom: 20px;
        margin-top: 60px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_pager {
        padding-top: 6.51042vw;
        padding-bottom: 3.90625vw;
        margin-top: 7.8125vw;
    }
}

.topic-detail_main_pager_anchor {
    text-decoration: none;
    color: #000;
    font-weight: bold;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_pager_anchor {
        font-size: 3.38542vw;
    }
}

.topic-detail_main_pager_anchor i {
    color: #8dc21f;
}

.topic-detail_main_pager_anchor:hover {
    opacity: 0.7;
}

@media only screen and (min-width: 769px) {
    .topic-detail_sidebar {
        width: 280px;
    }
}

.topic-detail_sidebar_heading {
    color: #fff;
    background-color: #c0b99d;
    font-weight: bold;
}

@media only screen and (min-width: 769px) {
    .topic-detail_sidebar_heading {
        padding: 12px 15px;
        border-radius: 5px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_sidebar_heading {
        padding: 3.125vw 3.90625vw;
        margin-top: 5.20833vw;
        border-radius: 1.30208vw;
    }
}

.topic-detail_sidebar_item {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    color: #000;
    text-decoration: none;
    border-bottom: 1px solid #c0b99d;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (min-width: 769px) {
    .topic-detail_sidebar_item {
        padding: 20px 0;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_sidebar_item {
        padding: 3.90625vw 0;
    }
}

.topic-detail_sidebar_item:hover {
    opacity: 0.7;
}

.topic-detail_sidebar_item_image {
    overflow: hidden;
    position: relative;
    border-radius: 10px;
}

@media only screen and (min-width: 769px) {
    .topic-detail_sidebar_item_image {
        width: 90px;
        height: 90px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_sidebar_item_image {
        width: 26.04167vw;
        height: 26.04167vw;
    }
}

.topic-detail_sidebar_item_text {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1;
}

@media only screen and (min-width: 769px) {
    .topic-detail_sidebar_item_text {
        margin-left: 15px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_sidebar_item_text {
        margin-left: 3.90625vw;
    }
}

.topic-detail_sidebar_item_text_title {
    line-height: 1.6;
}

@media only screen and (min-width: 769px) {
    .topic-detail_sidebar_item_text_title {
        font-size: 14px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_sidebar_item_text_title {
        font-size: 3.64583vw;
    }
}

.topic-detail_sidebar_item_text_time {
    color: #ff6600;
    display: block;
}

@media only screen and (min-width: 769px) {
    .topic-detail_sidebar_item_text_time {
        font-size: 13px;
        margin-top: 10px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_sidebar_item_text_time {
        margin-top: 2.60417vw;
        font-size: 3.64583vw;
    }
}

@media only screen and (min-width: 769px) {
    .pack-card {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }
}

@media only screen and (max-width: 768px) {
    .pack-card {
        margin-top: 7.8125vw;
    }
}

.pack-card_item {
    display: block;
    background-color: #fff;
    border-radius: 10px;
    -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
    box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
    text-decoration: none;
    color: black;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (min-width: 769px) {
    .pack-card_item {
        width: 515px;
        margin-top: 50px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-card_item {
        margin-top: 3.90625vw;
    }
}

.pack-card_item:hover {
    opacity: 0.7;
}

@media only screen and (min-width: 769px) {
    .pack-card_item_body {
        padding: 40px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-card_item_body {
        padding: 6.38021vw;
    }
}

.pack-card_item_message {
    font-weight: bold;
    line-height: 1.6;
}

@media only screen and (min-width: 769px) {
    .pack-card_item_message {
        font-size: 18px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-card_item_message {
        font-size: 3.90625vw;
    }
}

.pack-card_item_title {
    line-height: 1.8;
    font-weight: bold;
}

@media only screen and (min-width: 769px) {
    .pack-card_item_title {
        font-size: 24px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-card_item_title {
        font-size: 5.20833vw;
    }
}

.pack-card_item_title i {
    display: inline-block;
    margin: 0;
}

.pack-card_item_title i::before {
    color: #8dc21f;
}

.pack-card_item_new {
    font-weight: bold;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

@media only screen and (min-width: 769px) {
    .pack-card_item_new {
        margin-top: 5px;
    }
}

.pack-card_item_new i::before {
    color: #8dc21f;
    margin: 0;
}

@media only screen and (min-width: 769px) {
    .pack-card_item_new i::before {
        font-size: 20px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-card_item_new i::before {
        font-size: 4.16667vw;
    }
}

.pack-card_item_new_time {
    color: #edbc1f;
    line-height: 1.6;
}

@media only screen and (min-width: 769px) {
    .pack-card_item_new_time {
        margin: 0 5px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-card_item_new_time {
        font-size: 3.64583vw;
        margin: 0 0.65104vw;
    }
}

.pack-card_item_new_text {
    color: #ff6600;
    line-height: 1.6;
}

@media only screen and (max-width: 768px) {
    .pack-card_item_new_text {
        font-size: 3.64583vw;
    }
}

.pack-detail_heading {
    font-weight: bold;
    line-height: 1.6;
}

@media only screen and (min-width: 769px) {
    .pack-detail_heading {
        font-size: 34px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_heading {
        font-size: 6.77083vw;
        margin-top: 2.60417vw;
    }
}

.pack-detail_lead {
    font-weight: bold;
    line-height: 1.6;
}

@media only screen and (min-width: 769px) {
    .pack-detail_lead {
        font-size: 20px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_lead {
        font-size: 4.16667vw;
    }
}

@media only screen and (min-width: 769px) {
    .pack-detail_box {
        margin-top: 30px;
        padding-top: 40px;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        border-top: 2px solid #c0b99d;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_box {
        margin-top: 3.90625vw;
    }
}

@media only screen and (min-width: 769px) {
    .pack-detail_box_meta {
        width: 313px;
    }
}

@media only screen and (min-width: 769px) {
    .pack-detail_box_meta_image {
        margin-bottom: 40px;
    }
}

.pack-detail_box_meta_image img {
    border-radius: 5px;
}

.pack-detail_box_meta_data_heading {
    color: #fff;
    background-color: #c0b99d;
    font-weight: bold;
}

@media only screen and (min-width: 769px) {
    .pack-detail_box_meta_data_heading {
        padding: 12px 15px;
        margin-bottom: 15px;
        border-radius: 5px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_box_meta_data_heading {
        padding: 3.125vw 3.90625vw;
        margin-top: 5.20833vw;
        margin-bottom: 1.95313vw;
        border-radius: 1.30208vw;
    }
}

.pack-detail_box_meta_data_basic_wrap {
    line-height: 1.8;
}

.pack-detail_box_meta_data_basic_term {
    display: inline;
}

.pack-detail_box_meta_data_basic_term span {
    color: #ff8042;
}

.pack-detail_box_meta_data_basic_value {
    display: inline;
}

.pack-detail_box_body {
    line-height: 2;
}

@media only screen and (min-width: 769px) {
    .pack-detail_box_body {
        -webkit-box-flex: 1;
        -webkit-flex: 1;
        -ms-flex: 1;
        flex: 1;
        margin-left: 45px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_box_body {
        margin-top: 6.51042vw;
    }
}

.pack-detail_box_body p+p {
    margin-top: 1.5rem;
}

.pack-detail_sample_heading {
    background-color: #8dc21f;
    color: #fff;
    display: block;
    border-radius: 5px;
    text-align: center;
    text-decoration: none;
}

@media only screen and (min-width: 769px) {
    .pack-detail_sample_heading {
        margin-top: 50px;
        padding: 5px;
        font-size: 18px;
        margin-bottom: 40px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_sample_heading {
        padding: 2.60417vw 0;
        margin-top: 7.8125vw;
        margin-bottom: 7.8125vw;
        line-height: 1.6;
        font-size: 4.16667vw;
    }
}

.pack-detail_sample_heading span {
    font-weight: bold;
}

.pack-detail_box_body_contents {
    background-color: #fcfbf5;
    border: 1px solid #f1eede;
    border-radius: 10px;
    text-align: center;
}

@media only screen and (min-width: 769px) {
    .pack-detail_box_body_contents {
        padding: 50px 60px;
        margin-top: 40px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_box_body_contents {
        padding: 10.41667vw 3.90625vw;
        margin-top: 6.51042vw;
        margin-left: -6.51042vw;
        margin-right: -6.51042vw;
    }
}

@media only screen and (min-width: 769px) {
    .pack-detail_box_body_contents_btnArea {
        margin-bottom: 30px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_box_body_contents_btnArea {
        margin-bottom: 5.20833vw;
    }
}

.pack-detail_box_body_contents_btn {
    background-color: #edbc1f;
    color: #fff;
    border-radius: 100px;
    text-decoration: none;
    display: inline-block;
    font-weight: bold;
    -webkit-transition: opacity 0.2s ease;
    -o-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

@media only screen and (min-width: 769px) {
    .pack-detail_box_body_contents_btn {
        padding: 12px 40px;
        font-size: 20px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_box_body_contents_btn {
        padding: 1.5625vw 5.20833vw;
        font-size: 4.6875vw;
    }
}

@media only screen and (min-width: 769px) {
    .pack-detail_box_body_contents_btn img {
        margin-right: 1rem;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_box_body_contents_btn img {
        margin-right: .6rem;
        width: 5.85938vw;
    }
}

.pack-detail_box_body_contents_btn:hover {
    opacity: 0.7;
}

@media only screen and (min-width: 769px) {
    .pack-detail_box_body_contents_text {
        margin-top: 30px;
        font-size: 14px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_box_body_contents_text {
        margin-top: 5.20833vw;
        font-size: 3.38542vw;
    }
}

@media only screen and (min-width: 769px) {
    .pack-detail_sample_image {
        margin-bottom: 15px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_sample_image {
        margin-bottom: 3.25521vw;
    }
}

.pack-detail_sample_text {
    text-align: center;
    line-height: 1.5;
}

@media only screen and (min-width: 769px) {
    .pack-detail_sample_text {
        margin-bottom: 30px;
    }
}

@media only screen and (max-width: 768px) {
    .pack-detail_sample_text {
        margin-bottom: 5.20833vw;
    }
}

.topic-detail_main_profile {
    background-color: #fcfbf5;
    border-radius: 10px;
}

@media only screen and (min-width: 769px) {
    .topic-detail_main_profile {
        padding: 25px;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_profile {
        padding: 3.90625vw;
    }
}

@media only screen and (min-width: 769px) {
    .topic-detail_main_profile_image {
        width: 140px;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_profile_image {
        float: left;
        margin-right: 3.90625vw;
        margin-bottom: 3.90625vw;
    }
}

.topic-detail_main_profile_text {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1;
    line-height: 1.8;
}

@media only screen and (min-width: 769px) {
    .topic-detail_main_profile_text {
        font-size: 14px;
        margin-left: 20px;
    }
}

.topic-detail_main_profile_term {
    font-weight: bold;
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_profile_term {
        font-size: 3.38542vw;
    }
}

@media only screen and (max-width: 768px) {
    .topic-detail_main_profile_data {
        font-size: 3.38542vw;
    }
}

.uti-tal {
    text-align: left;
}

.uti-tac {
    text-align: center;
}

.uti-tar {
    text-align: right;
}

@media only screen and (min-width: 769px) {
    .uti-tal-pc {
        text-align: left;
    }
}

@media only screen and (min-width: 769px) {
    .uti-tac-pc {
        text-align: center;
    }
}

@media only screen and (min-width: 769px) {
    .uti-tar-pc {
        text-align: right;
    }
}

@media only screen and (max-width: 768px) {
    .uti-tal-sp {
        text-align: left;
    }
}

@media only screen and (max-width: 768px) {
    .uti-tac-sp {
        text-align: center;
    }
}

@media only screen and (max-width: 768px) {
    .uti-tar-sp {
        text-align: right;
    }
}

.uti-fl {
    float: left;
}

.uti-fr {
    float: right;
}

@media only screen and (min-width: 769px) {
    .uti-fl-pc {
        float: left;
    }
}

@media only screen and (min-width: 769px) {
    .uti-fr-pc {
        float: right;
    }
}

@media only screen and (max-width: 768px) {
    .uti-fl-sp {
        float: left;
    }
}

@media only screen and (max-width: 768px) {
    .uti-fr-sp {
        float: right;
    }
}

.uti-fwn {
    font-weight: normal;
}

.uti-fwb {
    font-weight: bold;
}

@media only screen and (min-width: 769px) {
    .uti-fwn-pc {
        font-weight: normal;
    }
}

@media only screen and (min-width: 769px) {
    .uti-fwb-pc {
        font-weight: bold;
    }
}

@media only screen and (max-width: 768px) {
    .uti-fwn-sp {
        font-weight: normal;
    }
}

@media only screen and (max-width: 768px) {
    .uti-fwb-sp {
        font-weight: bold;
    }
}

.uti-clearfix:before,
.uti-clearfix:after {
    content: " ";
    display: table;
}

.uti-clearfix:after {
    clear: both;
}

.uti-clearfix {
    *zoom: 1;
}

@media only screen and (max-width: 768px) {
    .uti-pc {
        display: none;
    }
}

@media only screen and (min-width: 769px) {
    .uti-sp {
        display: none;
    }
}

@media only screen and (min-width: 769px) {
    .uti-relative {
        position: relative;
    }
}

@media only screen and (max-width: 768px) {
    .uti-relative-sp {
        position: relative;
    }
}

.uti-block {
    display: block;
}

@media only screen and (max-width: 768px) {
    .uti-block-pc {
        display: block;
    }
}

@media only screen and (max-width: 768px) {
    .uti-block-sp {
        display: block;
    }
}

@media only screen and (min-width: 769px) {
    .uti-p {
        line-height: 2;
    }
}

@media only screen and (max-width: 768px) {
    .uti-p {
        font-size: 3.64583vw;
        line-height: 6.25vw;
    }
}


/*# sourceMappingURL=maps/main.css.map */