@charset "UTF-8";


html,
body,
p,
h1,
h2,
h3,
h4,
ul,
ol {
    margin: 0;
    padding: 0;
}

* {
    box-sizing: border-box;
}

body {
    padding-top: 30px;
    color: #333333;
    font-family: 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
    font-size: 16px;
    line-height: 22px;
    text-size-adjust: 100%;
}

a {
    color: #0033cc;
    font-weight: normal;
}

.book-campaign__kv {
    width: 743px;
    height: 430px;
    margin-bottom: 24px;
}

.book-campaign__main {
    padding: 16px 24px 48px;
    background-color: #022842;
}

.book-campaign__content {
    position: relative;
    margin-bottom: 40px;
    padding: 24px;
    background-color: #ffffff;
}

.book-campaign__content:last-child {
    margin-bottom: 0;
}

.book-campaign__content:before,
.book-campaign__content:after {
    content: '';
    position: absolute;
    width: 100%;
    height: 29px;
    background-image: url('/v2/img/static_page/book_campaign/newsaga/frame_left.png'),
    url('/v2/img/static_page/book_campaign/newsaga/frame_right.png');
    background-repeat: no-repeat;
    background-position: left, right;
    background-size: contain;
}

.book-campaign__content:before {
    top: 0;
    right: 0;
}

.book-campaign__content:after {
    right: 0;
    bottom: 0;
    transform: scale(1, -1);
}

.book-campaign__free {
    display: block;
    width: fit-content;
    margin: 0 auto 16px;
    color: #fff500;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    text-decoration-line: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

a.book-campaign__free:hover {
    opacity: 0.8;
    color: #fff500;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

.book-campaign__free-mark {
    font-size: 16px;
}

.book-campaign__free-store {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 8px;
}

.book-campaign__heading {
    width: 100%;
    height: auto;
    margin-bottom: 16px;
    padding: 16px;
    background-color: #e2e3ef;
    color: #001860;
    font-size: 28px;
    font-weight: bold;
    line-height: 30px;
    text-align: center;
}

.book-campaign__text {
    margin-bottom: 16px;
}

.book-campaign__text-special {
    color: #af0000;
    font-weight: bold;
}

.book-campaign__text-small {
    font-size: 14px;
    line-height: 18px;
}

.book-campaign__subhead {
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 2px solid #bf5353;
    color: #af0000;
    font-size: 24px;
    font-weight: bold;
    line-height: 1;
    text-align: center;
}

.book-campaign__annotation {
    font-size: 16px;
    font-weight: normal;
}

.book-campaign__target {
    margin-bottom: 32px;
    padding: 20px 36px 16px;
    border-radius: 10px;
    background-color: #e8e4d9;
    color: #001860;
    font-size: 22px;
    font-weight: bold;
    line-height: 30px;
}

.book-campaign__target-cover {
    margin-bottom: 8px;
    padding-left: 1em;
    font-size: 18px;
}

.book-campaign__target-image {
    display: block;
    width: 316px;
    height: 158px;
    margin: 0 auto;
}

.book-campaign__shop-list {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 16px;
    margin-bottom: 40px;
    padding-left: 1em;
}

.book-campaign__shop {
    width: calc(50% - 8px);
}

.book-campaign__title {
    color: #000000;
    font-weight: bold;
}

.book-campaign__kind {
    font-size: 20px;
}

.book-campaign__image {
    width: 100%;
    height: 374px;
    margin-bottom: 32px;
}

.book-campaign__image--comic {
    margin-bottom: 8px;
}

.book-campaign__detail {
    margin-bottom: 32px;
}

.book-campaign__comic {
    display: flex;
}

.book-campaign__comic-text {
    width: 305px;
    margin-right: 20px;
    font-weight: bold;
}

.book-campaign__comic-image {
    width: 200px;
    height: 284px;
}

.book-campaign__free-term {
    margin-bottom: 16px;
    padding: 8px;
    background-color: #efdfc8;
    color: #af0000;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
}

.book-campaign__free-annotation {
    display: block;
    padding-top: 8px;
    font-size: 14px;
    font-weight: normal;
    line-height: 16px;
}

.book-campaign__button {
    display: block;
    box-sizing: border-box;
    width: calc((100% - 8px) / 2);
    height: 63px;
    border: solid 2px #fede7c;
    background-color: #9f0f2e;
    color: white;
    font-size: 20px;
    font-weight: bold;
    line-height: 59px;
    text-align: center;
}

a.book-campaign__button:hover,
a.book-campaign__button:visited {
    color: white;
    text-decoration: none;
}

a.book-campaign__button:hover,
a.book-campaign__banner:hover {
    opacity: 0.8;
}

.book-campaign__banner {
    display: block;
    margin: 0 auto;
}

.book-campaign__break {
    display: none;
}
