@charset "UTF-8";
.m-t-0 { margin-top: 0px !important; }

.p-t-0 { padding-top: 0px !important; }

.m-b-0 { margin-bottom: 0px !important; }

.p-b-0 { padding-bottom: 0px !important; }

.m-l-0 { margin-left: 0px !important; }

.p-l-0 { padding-left: 0px !important; }

.m-r-0 { margin-right: 0px !important; }

.p-r-0 { padding-right: 0px !important; }

.m-t-5 { margin-top: 5px !important; }

.p-t-5 { padding-top: 5px !important; }

.m-b-5 { margin-bottom: 5px !important; }

.p-b-5 { padding-bottom: 5px !important; }

.m-l-5 { margin-left: 5px !important; }

.p-l-5 { padding-left: 5px !important; }

.m-r-5 { margin-right: 5px !important; }

.p-r-5 { padding-right: 5px !important; }

.m-t-10 { margin-top: 10px !important; }

.p-t-10 { padding-top: 10px !important; }

.m-b-10 { margin-bottom: 10px !important; }

.p-b-10 { padding-bottom: 10px !important; }

.m-l-10 { margin-left: 10px !important; }

.p-l-10 { padding-left: 10px !important; }

.m-r-10 { margin-right: 10px !important; }

.p-r-10 { padding-right: 10px !important; }

.m-t-15 { margin-top: 15px !important; }

.p-t-15 { padding-top: 15px !important; }

.m-b-15 { margin-bottom: 15px !important; }

.p-b-15 { padding-bottom: 15px !important; }

.m-l-15 { margin-left: 15px !important; }

.p-l-15 { padding-left: 15px !important; }

.m-r-15 { margin-right: 15px !important; }

.p-r-15 { padding-right: 15px !important; }

.m-t-20 { margin-top: 20px !important; }

.p-t-20 { padding-top: 20px !important; }

.m-b-20 { margin-bottom: 20px !important; }

.p-b-20 { padding-bottom: 20px !important; }

.m-l-20 { margin-left: 20px !important; }

.p-l-20 { padding-left: 20px !important; }

.m-r-20 { margin-right: 20px !important; }

.p-r-20 { padding-right: 20px !important; }

.m-t-25 { margin-top: 25px !important; }

.p-t-25 { padding-top: 25px !important; }

.m-b-25 { margin-bottom: 25px !important; }

.p-b-25 { padding-bottom: 25px !important; }

.m-l-25 { margin-left: 25px !important; }

.p-l-25 { padding-left: 25px !important; }

.m-r-25 { margin-right: 25px !important; }

.p-r-25 { padding-right: 25px !important; }

.m-t-30 { margin-top: 30px !important; }

.p-t-30 { padding-top: 30px !important; }

.m-b-30 { margin-bottom: 30px !important; }

.p-b-30 { padding-bottom: 30px !important; }

.m-l-30 { margin-left: 30px !important; }

.p-l-30 { padding-left: 30px !important; }

.m-r-30 { margin-right: 30px !important; }

.p-r-30 { padding-right: 30px !important; }

.m-t-35 { margin-top: 35px !important; }

.p-t-35 { padding-top: 35px !important; }

.m-b-35 { margin-bottom: 35px !important; }

.p-b-35 { padding-bottom: 35px !important; }

.m-l-35 { margin-left: 35px !important; }

.p-l-35 { padding-left: 35px !important; }

.m-r-35 { margin-right: 35px !important; }

.p-r-35 { padding-right: 35px !important; }

.m-t-40 { margin-top: 40px !important; }

.p-t-40 { padding-top: 40px !important; }

.m-b-40 { margin-bottom: 40px !important; }

.p-b-40 { padding-bottom: 40px !important; }

.m-l-40 { margin-left: 40px !important; }

.p-l-40 { padding-left: 40px !important; }

.m-r-40 { margin-right: 40px !important; }

.p-r-40 { padding-right: 40px !important; }

.m-t-45 { margin-top: 45px !important; }

.p-t-45 { padding-top: 45px !important; }

.m-b-45 { margin-bottom: 45px !important; }

.p-b-45 { padding-bottom: 45px !important; }

.m-l-45 { margin-left: 45px !important; }

.p-l-45 { padding-left: 45px !important; }

.m-r-45 { margin-right: 45px !important; }

.p-r-45 { padding-right: 45px !important; }

.m-t-50 { margin-top: 50px !important; }

.p-t-50 { padding-top: 50px !important; }

.m-b-50 { margin-bottom: 50px !important; }

.p-b-50 { padding-bottom: 50px !important; }

.m-l-50 { margin-left: 50px !important; }

.p-l-50 { padding-left: 50px !important; }

.m-r-50 { margin-right: 50px !important; }

.p-r-50 { padding-right: 50px !important; }

.m-t-55 { margin-top: 55px !important; }

.p-t-55 { padding-top: 55px !important; }

.m-b-55 { margin-bottom: 55px !important; }

.p-b-55 { padding-bottom: 55px !important; }

.m-l-55 { margin-left: 55px !important; }

.p-l-55 { padding-left: 55px !important; }

.m-r-55 { margin-right: 55px !important; }

.p-r-55 { padding-right: 55px !important; }

.m-t-60 { margin-top: 60px !important; }

.p-t-60 { padding-top: 60px !important; }

.m-b-60 { margin-bottom: 60px !important; }

.p-b-60 { padding-bottom: 60px !important; }

.m-l-60 { margin-left: 60px !important; }

.p-l-60 { padding-left: 60px !important; }

.m-r-60 { margin-right: 60px !important; }

.p-r-60 { padding-right: 60px !important; }

.m-t-65 { margin-top: 65px !important; }

.p-t-65 { padding-top: 65px !important; }

.m-b-65 { margin-bottom: 65px !important; }

.p-b-65 { padding-bottom: 65px !important; }

.m-l-65 { margin-left: 65px !important; }

.p-l-65 { padding-left: 65px !important; }

.m-r-65 { margin-right: 65px !important; }

.p-r-65 { padding-right: 65px !important; }

.m-t-70 { margin-top: 70px !important; }

.p-t-70 { padding-top: 70px !important; }

.m-b-70 { margin-bottom: 70px !important; }

.p-b-70 { padding-bottom: 70px !important; }

.m-l-70 { margin-left: 70px !important; }

.p-l-70 { padding-left: 70px !important; }

.m-r-70 { margin-right: 70px !important; }

.p-r-70 { padding-right: 70px !important; }

.m-t-75 { margin-top: 75px !important; }

.p-t-75 { padding-top: 75px !important; }

.m-b-75 { margin-bottom: 75px !important; }

.p-b-75 { padding-bottom: 75px !important; }

.m-l-75 { margin-left: 75px !important; }

.p-l-75 { padding-left: 75px !important; }

.m-r-75 { margin-right: 75px !important; }

.p-r-75 { padding-right: 75px !important; }

.m-t-80 { margin-top: 80px !important; }

.p-t-80 { padding-top: 80px !important; }

.m-b-80 { margin-bottom: 80px !important; }

.p-b-80 { padding-bottom: 80px !important; }

.m-l-80 { margin-left: 80px !important; }

.p-l-80 { padding-left: 80px !important; }

.m-r-80 { margin-right: 80px !important; }

.p-r-80 { padding-right: 80px !important; }

.m-t-85 { margin-top: 85px !important; }

.p-t-85 { padding-top: 85px !important; }

.m-b-85 { margin-bottom: 85px !important; }

.p-b-85 { padding-bottom: 85px !important; }

.m-l-85 { margin-left: 85px !important; }

.p-l-85 { padding-left: 85px !important; }

.m-r-85 { margin-right: 85px !important; }

.p-r-85 { padding-right: 85px !important; }

.m-t-90 { margin-top: 90px !important; }

.p-t-90 { padding-top: 90px !important; }

.m-b-90 { margin-bottom: 90px !important; }

.p-b-90 { padding-bottom: 90px !important; }

.m-l-90 { margin-left: 90px !important; }

.p-l-90 { padding-left: 90px !important; }

.m-r-90 { margin-right: 90px !important; }

.p-r-90 { padding-right: 90px !important; }

.m-t-95 { margin-top: 95px !important; }

.p-t-95 { padding-top: 95px !important; }

.m-b-95 { margin-bottom: 95px !important; }

.p-b-95 { padding-bottom: 95px !important; }

.m-l-95 { margin-left: 95px !important; }

.p-l-95 { padding-left: 95px !important; }

.m-r-95 { margin-right: 95px !important; }

.p-r-95 { padding-right: 95px !important; }

.m-t-100 { margin-top: 100px !important; }

.p-t-100 { padding-top: 100px !important; }

.m-b-100 { margin-bottom: 100px !important; }

.p-b-100 { padding-bottom: 100px !important; }

.m-l-100 { margin-left: 100px !important; }

.p-l-100 { padding-left: 100px !important; }

.m-r-100 { margin-right: 100px !important; }

.p-r-100 { padding-right: 100px !important; }

.pc { display: block; }

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

.sp { display: none; }

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

@media screen and (max-width: 768px) { html, body { overflow-x: hidden; }
  body { -webkit-text-size-adjust: 100%; }
  input, textarea { border-radius: 0; -webkit-appearance: none; }
  input[type="radio"] { -webkit-appearance: radio; }
  input[type="checkbox"] { -webkit-appearance: checkbox; } }

@media screen and (max-width: 499px) { .spBlock { display: block; } }

/* =======================================

Browser Reset CSS
Last Up Date 19/04/01

========================================== */
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, p, blockquote, table, th, td, figure { margin: 0; padding: 0; }

html, body { color: #ffffff; }

body { font-family: "Helvetica Neue" , Helvetica , Arial , Verdana , Roboto , "游ゴシック" , "Yu Gothic" , "游ゴシック体" , "YuGothic" , "ヒラギノ角ゴ Pro W3" , "Hiragino Kaku Gothic Pro" , "Meiryo UI" , "メイリオ" , Meiryo , "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif; font-weight: 500; -webkit-font-smoothing: antialiased; background-color: #83817F; }

* html body { font-size: small; }

*:first-child + html body { font-size: small; }

a { outline: none; color: #ffffff; text-decoration: none; backface-visibility: hidden; }

.hover a:hover img.scale { -webkit-transform: scale(1.1); -moz-transform: scale(1.1); -o-transform: scale(1.1); -ms-transform: scale(1.1); transform: scale(1.1); }

.trans, #menu, .globalNavi__link li a, .globalNavi__tag a, .globalFooter__logo, .entry-header__text a, .entry-header__tag li a, .el-btn-border, .bl-related-articles__link, .bl-related-articles__info__img, .bl-related-articles__info__text a, .bl-related-articles__tag li a { transition: all 0.5s ease 0s; -webkit-transition: all 0.5s ease; -moz-transition: all 0.5s ease; -o-transition: all 0.5s ease; }

img { border: 0; }

h1, h2, h3, h4, h5, h6 { clear: both; font-size: 100%; font-weight: normal; }

ul, dl, ol { text-indent: 0; }

li { list-style: none; }

address, caption, cite, code, dfn, em, th, var { font-style: normal; font-weight: normal; }

sup { vertical-align: text-top; }

sub { vertical-align: text-bottom; }

input, textarea, select { font-family: inherit; font-size: inherit; font-weight: inherit; }

* html input, * html textarea, * html select { font-size: 100%; }

*:first-child + html + input, *:first-child html + textarea, *:first-child + html select { font-size: 100%; }

table { border-collapse: collapse; border-spacing: 0; font-size: inherit; table-layout: fixed; }

th, td { text-align: left; vertical-align: top; }

caption { text-align: left; }

pre, code, kbd, samp, tt { font-family: monospace; }

* html pre, * html code, * html kbd, * html samp, * html tt { font-size: 100%; line-height: 100%; }

*:first-child + html pre, *:first-child html + code, *:first-child html + kbd, *:first-child + html + samp, *:first-child + html tt { font-size: 108%; line-height: 100%; }

input, select, textarea { font-size: 100%; font-family: Verdana, Helvetica, sans-serif; }

.clear { clear: both; }

/*-- clearfix --*/
.clearfix:after { content: ""; display: block; clear: both; }

/* =======================================

Structure CSS

========================================== */
.main-wrapper { border-width: 1px 0 0 0; border-style: solid; border-color: #908E8C; }

.ly-wrapper-sm { max-width: 800px; margin-left: auto; margin-right: auto; padding: 0 20px; }

.ly-wrapper { max-width: 1088px; margin-left: auto; margin-right: auto; padding: 0 20px; }

.ly-wrapper-lg { padding: 20px; box-sizing: border-box; max-width: 1128px; margin-left: auto; margin-right: auto; }

.multi-columns { display: flex; flex-wrap: wrap; }

.multi-columns[data-column="2"] .multi-columns__body { width: calc(50% - 20px); margin: 0 40px 40px 0; }

.multi-columns[data-column="2"] .multi-columns__body:nth-child(2n) { margin-right: 0; }

@media screen and (max-width: 768px) { .multi-columns[data-column="2"] .multi-columns__body { width: calc(50% - 10px); margin: 0 20px 20px 0; } }

@media screen and (max-width: 499px) { .multi-columns[data-column="2"] .multi-columns__body { width: 100%; margin: 0 0 20px 0; } }

.multi-columns[data-column="3"] .multi-columns__body { width: calc((100% - 80px) / 3); margin: 0 40px 40px 0; }

.multi-columns[data-column="3"] .multi-columns__body:nth-child(3n) { margin-right: 0; }

@media screen and (max-width: 768px) { .multi-columns[data-column="3"] .multi-columns__body { width: calc((100% - 40px) / 3); margin: 0 20px 32px 0; } }

@media screen and (max-width: 499px) { .multi-columns[data-column="3"] .multi-columns__body { width: 100%; margin: 0 0 32px 0; } }

.multi-columns[data-column="3"] .multi-columns__body--narrow { width: calc((100% - 40px) / 3); margin: 0 20px 20px 0; }

.multi-columns[data-column="3"] .multi-columns__body--narrow:nth-child(3n) { margin-right: 0; }

@media screen and (max-width: 768px) { .multi-columns[data-column="3"] .multi-columns__body--narrow { width: calc((100% - 40px) / 3); margin: 0 20px 20px 0; } }

@media screen and (max-width: 499px) { .multi-columns[data-column="3"] .multi-columns__body--narrow { width: 100%; margin: 0 0 20px 0; } }

.multi-columns[data-column="4"] .multi-columns__body { width: calc(25% - 30px); margin: 0 40px 0 0; }

.multi-columns[data-column="4"] .multi-columns__body:nth-child(4n) { margin-right: 0; }

@media screen and (max-width: 768px) { .multi-columns[data-column="4"] .multi-columns__body { width: calc(25% - 15px); margin: 0 20px 0 0; } }

@media screen and (max-width: 499px) { .multi-columns[data-column="4"] .multi-columns__body { width: 100%; margin: 0 0 30px 0; } }

.multi-columns[data-column="4"] .multi-columns__body--narrow { width: calc(25% - 15px); margin: 0 20px 0 0; }

.multi-columns[data-column="4"] .multi-columns__body--narrow:nth-child(4n) { margin-right: 0; }

@media screen and (max-width: 768px) { .multi-columns[data-column="4"] .multi-columns__body--narrow { width: calc((100% - 30px) / 4); margin: 0 10px 0 0; } }

@media screen and (max-width: 499px) { .multi-columns[data-column="4"] .multi-columns__body--narrow { width: 100%; margin: 0 0 10px 0; } }

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

.multi-columns__title { font-size: 20px; font-weight: bold; line-height: 140%; margin: 20px 0 0 0; }

.multi-columns__text { margin: 20px 0 0 0; line-height: 180%; font-size: 18px; }

/* =======================================

Text Decorations CSS

========================================== */
/* =======================================

Header CSS

========================================== */
#globalHeader { height: 120px; box-sizing: border-box; padding: 16px 0 0 35px; position: relative; z-index: 1; }

@media screen and (max-width: 768px) { #globalHeader { height: 60px; padding: 0 0 0 20px; } }

#site-title a { display: inline-block; width: 238px; position: relative; }

#site-title a:hover { opacity: 0.75; }

@media screen and (max-width: 768px) { #site-title a { width: 124px; z-index: 3; } }

#site-title a img { width: 100%; height: auto; }

#menu { display: block; width: 128px; height: 120px; position: absolute; cursor: pointer; z-index: 3; text-indent: -9999px; top: 0; right: 0; background-image: url(../img/common/img_menu.svg); background-repeat: no-repeat; background-size: 128px 120px; }

#menu:hover { opacity: 0.75; }

@media screen and (max-width: 768px) { #menu { width: 64px; height: 60px; background-size: 64px 60px; } }

#menu.active { background-image: url(../img/common/img_menu_close.svg); }

.header-date { display: none; }

@media screen and (max-width: 768px) { .header-date { display: block; position: absolute; font-size: 16px; font-weight: bold; top: 20px; right: 75px; text-transform: uppercase; border-width: 0 0 0 1px; border-style: solid; border-color: #A9A7A6; padding: 0 0 0 15px; } }

#globalNavi { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100vh; background-color: #9D906E; }

.globalNavi { display: flex; width: 100%; height: 100vh; align-items: center; }

.globalNavi__wrapper { width: 100%; box-sizing: border-box; max-width: 1084px; margin: 0 auto; padding: 0 24px; }

.globalNavi__link { display: flex; flex-wrap: wrap; }

.globalNavi__link li { margin: 0 14px 14px 0; padding: 0 14px 0 0; font-size: 28px; font-weight: bold; position: relative; }

@media screen and (max-width: 768px) { .globalNavi__link li { font-size: 24px; } }

.globalNavi__link li::after { content: "/"; position: absolute; top: 0; right: -5px; }

.globalNavi__link li:last-child { margin-right: 0; padding-right: 0; }

.globalNavi__link li:last-child::after { display: none; }

.globalNavi__link li a { display: inline-block; }

.globalNavi__link li a:hover { opacity: 0.75; }

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

@media screen and (max-width: 768px) { .globalNavi__tag { margin: 20px 0 0 0; } }

.globalNavi__tag a { font-size: 30px !important; font-weight: bold; margin: 0 14px 8px 0; color: #646B64; }

@media screen and (max-width: 768px) { .globalNavi__tag a { font-size: 20px !important; } }

.globalNavi__tag a:hover { opacity: 0.75; }

.globalNavi__tag a::before { content: '#'; }

/* =======================================

Footer CSS

========================================== */
#globalFooter { background-color: #403E3D; text-align: center; padding: 100px 0; }

@media screen and (max-width: 768px) { #globalFooter { padding: 85px 0; } }

.globalFooter__logo { display: inline-block; }

.globalFooter__logo:hover { opacity: 0.75; }

.globalFooter__copy { margin: 20px 0 0 0; font-size: 10px; }

/* =======================================

共通

========================================== */
.bread-crumbs { font-size: 13px; padding: 15px 20px; box-sizing: border-box; max-width: 1128px; margin: 0 auto; color: #E6E6E5; }

@media screen and (max-width: 768px) { .bread-crumbs { font-size: 10px; padding: 10px 20px; white-space: nowrap; overflow-x: scroll; } }

.bread-crumbs a { color: #E6E6E5; text-decoration: underline; }

.bread-crumbs a:hover { text-decoration: none; }

.entry-header { max-width: 960px; margin: 80px auto 0 auto; padding: 0 20px; }

@media screen and (max-width: 768px) { .entry-header { margin: 30px auto 0 auto; } }

.entry-header__title { font-size: 46px; font-weight: bold; line-height: 130%; margin: 0 0 20px 0; }

@media screen and (max-width: 768px) { .entry-header__title { font-size: 32px; } }

.entry-header__info { display: flex; align-items: center; flex-wrap: wrap; }

.entry-header__illust { width: 54px; flex-shrink: 0; }

.entry-header__illust img { width: 100%; border-radius: 27px; }

.entry-header__text { margin: 0 0 0 10px; }

.entry-header__text time { display: block; font-size: 15px; font-weight: bold; color: #C1C0BF; }

@media screen and (max-width: 768px) { .entry-header__text time { font-size: 13px; } }

.entry-header__text a { font-size: 17px; font-weight: bold; }

@media screen and (max-width: 768px) { .entry-header__text a { font-size: 15px; } }

.entry-header__text a:hover { opacity: 0.75; }

.entry-header__tag { margin: 15px 0 0 0; display: flex; flex-wrap: wrap; width: 100%; }

.entry-header__tag li { margin: 0 10px 10px 0; }

.entry-header__tag li a { font-size: 17px; font-style: italic; color: #646B64; }

@media screen and (max-width: 768px) { .entry-header__tag li a { font-size: 13px; color: #FFD637; } }

.entry-header__tag li a:hover { color: #FFD637; }

.bl-main-img { margin: 60px auto 100px auto; max-width: 960px; padding: 0 20px; }

@media screen and (max-width: 768px) { .bl-main-img { margin: 40px 0 40px 0; } }

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

.bl-blog-entry { margin: 100px 0; }

@media screen and (max-width: 768px) { .bl-blog-entry { margin: 40px 0; } }

.bl-blog-entry h1 { margin: 100px 0 50px 0; font-size: 36px; font-weight: bold; line-height: 130%; }

@media screen and (max-width: 768px) { .bl-blog-entry h1 { margin: 40px 0 32px 0; font-size: 28px; } }

.bl-blog-entry > h1 { margin-top: 0; }

.bl-blog-entry p { font-size: 17px; line-height: 200%; }

@media screen and (max-width: 768px) { .bl-blog-entry p { font-size: 15px; } }

.bl-blog-entry h2 { font-size: 32px; font-weight: bold; line-height: 150%; margin: 70px 0 40px 0; }

@media screen and (max-width: 768px) { .bl-blog-entry h2 { font-size: 24px; line-height: 130%; margin: 40px 0 28px 0; } }

.bl-blog-entry h3 { font-size: 24px; font-weight: bold; line-height: 150%; margin: 60px 0 40px 0; }

@media screen and (max-width: 768px) { .bl-blog-entry h3 { font-size: 20px; line-height: 130%; margin: 40px 0 24px 0; } }

.bl-blog-entry h4 { font-size: 20px; font-weight: bold; line-height: 150%; margin: 50px 0 30px 0; }

@media screen and (max-width: 768px) { .bl-blog-entry h4 { font-size: 18px; line-height: 130%; margin: 40px 0 20px 0; } }

.bl-blog-entry h5 { font-size: 18px; font-weight: bold; line-height: 150%; margin: 45px 0 25px 0; }

@media screen and (max-width: 768px) { .bl-blog-entry h5 { font-size: 16px; line-height: 130%; margin: 40px 0 20px 0; } }

.bl-blog-entry a { color: #1000C9; text-decoration: underline; }

.bl-blog-entry a:hover { text-decoration: none; }

.bl-blog-entry ul { margin: 40px 0; }

@media screen and (max-width: 768px) { .bl-blog-entry ul { margin: 30px 0; } }

.bl-blog-entry ul li { line-height: 160%; font-size: 17px; margin: 0 0 10px 0; padding: 0 0 0 14px; position: relative; }

.bl-blog-entry ul li:last-child { margin-bottom: 0; }

.bl-blog-entry ul li::after { content: ""; display: block; width: 6px; height: 6px; border-radius: 3px; background-color: #fff; position: absolute; top: 10px; left: 0; }

.bl-blog-entry ol { margin: 40px 0; }

@media screen and (max-width: 768px) { .bl-blog-entry ol { margin: 30px 0; } }

.bl-blog-entry ol li { line-height: 160%; font-size: 17px; margin: 0 0 10px 1.2em; position: relative; list-style-type: decimal; }

.bl-blog-entry ol li:last-child { margin-bottom: 0; }

.bl-blog-entry table { border-width: 1px 0 0 0; border-style: solid; border-color: #B8B7B6; }

@media screen and (max-width: 499px) { .bl-blog-entry table { display: block; }
  .bl-blog-entry table tr, .bl-blog-entry table tbody, .bl-blog-entry table thead { display: block; } }

.bl-blog-entry table th, .bl-blog-entry table td { border-width: 0 0 1px 0; border-style: solid; border-color: #B8B7B6; padding: 20px 20px 20px 0; }

.bl-blog-entry table th:last-child, .bl-blog-entry table td:last-child { padding-right: 0; }

@media screen and (max-width: 499px) { .bl-blog-entry table th:last-child, .bl-blog-entry table td:last-child { border-width: 0 0 1px 0; display: block; } }

@media screen and (max-width: 499px) { .bl-blog-entry table th, .bl-blog-entry table td { padding: 0 0 20px 0; border-width: 0; }
  .bl-blog-entry table th:first-child, .bl-blog-entry table td:first-child { padding-top: 20px; } }

.el-img-full { margin-bottom: 76px; }

@media screen and (max-width: 499px) { .el-img-full { margin-bottom: 30px; } }

.el-img-full img { width: 100%; height: auto; }

.el-img-vertical { width: 70%; margin-left: auto; margin-right: auto; margin-bottom: 76px; }

@media screen and (max-width: 768px) { .el-img-vertical { width: 100%; } }

@media screen and (max-width: 499px) { .el-img-vertical { margin-bottom: 30px; } }

.el-img-vertical img { width: 100%; height: auto; }

@media screen and (max-width: 768px) { .el-img-vertical img { display: block; width: 70%; margin: 0 auto; } }

.el-img-right { margin-right: calc(((-100vw + 800px) / 2)); margin-bottom: 76px; }

@media screen and (max-width: 768px) { .el-img-right { margin-right: 0; } }

@media screen and (max-width: 499px) { .el-img-right { margin-bottom: 30px; } }

.el-img-right img { width: 100%; height: auto; }

.el-img-right-vertical { margin-right: calc(((-100vw + 800px) / 2)); margin-bottom: 76px; }

@media screen and (max-width: 768px) { .el-img-right-vertical { margin-right: 0; } }

@media screen and (max-width: 499px) { .el-img-right-vertical { margin-bottom: 30px; } }

.el-img-right-vertical img { width: 50vw; height: auto; margin: 0 0 0 auto; display: block; }

@media screen and (max-width: 768px) { .el-img-right-vertical img { width: 70%; margin: 0 auto; } }

.el-img-right-vertical .el-img-caption { width: 50vw; margin: 15px 0 0 auto; }

@media screen and (max-width: 768px) { .el-img-right-vertical .el-img-caption { width: 100%; } }

.el-img-caption { font-size: 14px; line-height: 160%; margin: 15px 0 0 0; }

@media screen and (max-width: 768px) { .el-img-caption { font-size: 11px; } }

.el-img-slide { margin-bottom: 76px; }

@media screen and (max-width: 499px) { .el-img-slide { margin-bottom: 30px; } }

.el-img-slide img { width: 100%; height: auto; }

.el-img-slide .slick-dots { margin: 20px 0 0 0; display: flex; justify-content: center; }

@media screen and (max-width: 768px) { .el-img-slide .slick-dots { margin: 15px 0 0 0; } }

.el-img-slide .slick-dots li { margin: 0 7.5px; padding: 0; line-height: 1; }

.el-img-slide .slick-dots li::after { display: none; }

.el-img-slide .slick-dots li button { text-indent: -9999px; background-color: #A8A6A5; width: 14px; height: 14px; border-radius: 7px; cursor: pointer; border-width: 0; }

.el-img-slide .slick-dots li.slick-active button { background-color: #403E3D; }

.el-img-parallax { margin-left: calc(((-100vw + 800px) / 2)); margin-right: calc(((-100vw + 800px) / 2)); margin-bottom: 76px; }

@media screen and (max-width: 768px) { .el-img-parallax { margin-left: -20px; margin-right: -20px; } }

@media screen and (max-width: 499px) { .el-img-parallax { margin-bottom: 30px; } }

.el-img-parallax img { display: block; width: 100%; height: auto; }

.el-img-two-columns { display: flex; flex-wrap: wrap; margin-bottom: 36px; margin-left: calc(((-100vw + 1088px) / 2)); margin-right: calc(((-100vw + 1088px) / 2)); }

@media screen and (max-width: 1088px) { .el-img-two-columns { margin-left: 20px; margin-right: 20px; } }

@media screen and (max-width: 768px) { .el-img-two-columns { margin-left: 0; margin-right: 0; } }

.el-img-two-columns figure { width: calc(50% - 20px); margin: 0 40px 40px 0; }

@media screen and (max-width: 768px) { .el-img-two-columns figure { width: calc(50% - 10px); margin: 0 20px 40px 0; } }

@media screen and (max-width: 499px) { .el-img-two-columns figure { width: 100%; margin: 0 0 40px 0; } }

.el-img-two-columns figure:nth-child(2n) { margin-right: 0; }

.el-img-two-columns figure img { width: 100%; height: auto; }

.bl-btn-navi { margin: 100px 0 120px 0; display: flex; justify-content: space-between; }

@media screen and (max-width: 499px) { .bl-btn-navi { display: none; } }

.bl-btn-navi__box { width: calc((100% - 40px) / 3); }

.bl-btn-navi__box .el-btn-border { width: 100%; }

.el-btn-border { border-width: 1px; border-style: solid; border-color: #EAEAEA; height: 60px; display: flex; justify-content: center; align-items: center; font-size: 16px; font-weight: bold; }

.el-btn-border:hover { opacity: 0.75; }

.el-btn-border[data-type="prev"] { background-image: url(../img/common/ico_angle_left_white.svg); background-repeat: no-repeat; background-position: 20px center; }

.el-btn-border[data-type="next"] { background-image: url(../img/common/ico_angle_right_white.svg); background-repeat: no-repeat; background-position: right 20px center; }

.bl-article-author { background-color: #646B64; color: #fff; padding: 100px 0; }

@media screen and (max-width: 768px) { .bl-article-author { padding: 60px 0; } }

.bl-article-author__wrapper { display: flex; }

@media screen and (max-width: 499px) { .bl-article-author__wrapper { flex-direction: column; } }

.bl-article-author__left { width: 284px; box-sizing: border-box; padding: 0 20px 0 0; display: flex; align-items: flex-start; }

@media screen and (max-width: 499px) { .bl-article-author__left { width: 100%; padding: 0 0 25px 0; } }

.bl-article-author__right { width: calc(100% - 284px); }

@media screen and (max-width: 499px) { .bl-article-author__right { width: 100%; } }

.bl-article-author__illust { width: 98px; height: 98px; box-sizing: border-box; border-radius: 49px; flex-shrink: 0; }

@media screen and (max-width: 768px) { .bl-article-author__illust { width: 80px; height: 80px; border-radius: 40px; } }

.bl-article-author__info { padding: 0 0 0 20px; }

.bl-article-author__job { font-size: 14px; font-weight: bold; margin: 0 0 10px 0; }

@media screen and (max-width: 768px) { .bl-article-author__job { font-size: 13px; } }

.bl-article-author__name { font-size: 23px; font-weight: bold; margin: 0 0 5px 0; }

@media screen and (max-width: 768px) { .bl-article-author__name { font-size: 21px; } }

.bl-article-author__en { font-size: 12px; font-weight: bold; }

@media screen and (max-width: 768px) { .bl-article-author__en { font-size: 11px; } }

.bl-article-author__title { font-weight: bold; margin: 0 0 20px 0; }

.bl-article-author__description { font-size: 14px; line-height: 180%; }

.bl-related-articles { padding: 100px 0; }

@media screen and (max-width: 768px) { .bl-related-articles { padding: 60px 0; } }

.bl-related-articles__title { color: #fff; font-weight: bold; font-size: 40px; text-align: center; margin: 0 0 50px 0; }

@media screen and (max-width: 768px) { .bl-related-articles__title { font-size: 28px; margin: 0 0 20px 0; } }

.bl-related-articles__wrapper { display: flex; flex-wrap: wrap; }

@media screen and (max-width: 499px) { .bl-related-articles__wrapper { flex-direction: column; } }

.bl-related-articles__box { width: calc((100% - 80px) / 3); margin: 0 40px 40px 0; display: inline-block; }

@media screen and (max-width: 768px) { .bl-related-articles__box { width: calc((100% - 40px) / 3); margin: 0 20px 30px 0; } }

@media screen and (max-width: 499px) { .bl-related-articles__box { width: 100%; border-width: 0 0 1px 0; border-color: #646B64; border-style: solid; margin: 0; padding: 20px 0; } }

.bl-related-articles__box:nth-child(3n) { margin-right: 0; }

.bl-related-articles__link:hover { opacity: 0.75; }

.bl-related-articles__img { height: 224px; overflow: hidden; text-align: center; }

@media screen and (max-width: 768px) { .bl-related-articles__img { height: 140px; } }

@media screen and (max-width: 499px) { .bl-related-articles__img { width: 100px; height: 80px; float: left; } }

.bl-related-articles__img img { width: auto; height: 224px; }

@media screen and (max-width: 768px) { .bl-related-articles__img img { height: 150px; } }

@media screen and (max-width: 499px) { .bl-related-articles__img img { max-width: 100%; height: auto; max-height: 80px; } }

.bl-related-articles__article-title { font-size: 18px; font-weight: bold; margin: 20px 0 15px 0; }

@media screen and (max-width: 768px) { .bl-related-articles__article-title { font-size: 16px; margin: 10px 0 15px 0; } }

@media screen and (max-width: 499px) { .bl-related-articles__article-title { margin: 0 0 10px 120px; } }

.bl-related-articles__info { display: flex; align-items: flex-start; }

@media screen and (max-width: 499px) { .bl-related-articles__info { margin: 0 0 0 120px; } }

.bl-related-articles__info__img { width: 40px; flex-shrink: 0; }

.bl-related-articles__info__img:hover { opacity: 0.75; }

.bl-related-articles__info__img img { width: 100%; height: auto; border-radius: 50%; }

.bl-related-articles__info__text { margin: 5px 0 0 8px; }

.bl-related-articles__info__text time { display: block; font-size: 12px; color: #C1C0BF; }

.bl-related-articles__info__text a { display: block; font-size: 13px; color: #E6E6E5; font-weight: bold; }

.bl-related-articles__info__text a:hover { opacity: 0.75; }

.bl-related-articles__tag { display: flex; flex-wrap: wrap; margin: 5px 0 0 0; }

@media screen and (max-width: 499px) { .bl-related-articles__tag { margin: 5px 0 0 120px; } }

.bl-related-articles__tag li { margin: 0 10px 5px 0; font-style: italic; font-size: 13px; font-weight: bold; }

.bl-related-articles__tag li a { color: #C1AB5B; }

.bl-related-articles__tag li a:hover { opacity: 0.75; }

.page-header__title { margin: 80px 0 80px 0; font-size: 60px; font-weight: bold; line-height: 130%; }

@media screen and (max-width: 768px) { .page-header__title { font-size: 36px; margin: 40px 0 60px 0; } }

.editor-card { border-width: 1px 0 0 0; border-style: solid; border-color: #9C9A99; padding: 36px 0; font-weight: bold; }

@media screen and (max-width: 768px) { .editor-card { padding: 30px 0; } }

.editor-card__job { font-size: 14px; margin: 0 0 10px 0; }

.editor-card__name { font-size: 20px; margin: 0 0 20px 0; }

.editor-card__info { font-size: 12px; line-height: 180%; }

.editor-card__info a { text-decoration: underline; }

.editor-card__info a:hover { text-decoration: none; }

.story { background-image: url(../img/common/bg_story.jpg); background-repeat: no-repeat; background-position: center; background-size: cover; text-align: center; padding: 100px 20px 40px 20px; }

@media screen and (max-width: 768px) { .story { padding: 80px 20px; } }

.story dt { font-size: 26px; font-weight: bold; line-height: 140%; margin: 0 0 50px 0; }

.story dd { font-size: 16px; line-height: 180%; }

@media screen and (max-width: 768px) { .story dd { font-size: 14px; } }

/* =======================================

トップページ

========================================== */
.home-kv { height: 100vh; margin: -120px 0 0 0; position: relative; }

@media screen and (max-width: 768px) { .home-kv { margin: 0; height: auto; } }

.home-kv__img { position: absolute; right: 128px; bottom: 0; width: calc(50vw - 128px); height: 100vh; }

@media screen and (max-width: 768px) { .home-kv__img { position: relative; right: inherit; bottom: inherit; width: auto; height: auto; margin: 30px 12vw 12px 12vw; } }

.home-kv__img img { object-fit: cover; width: 100%; height: 100%; }

@media screen and (max-width: 768px) { .home-kv__img img { height: auto; } }

.home-kv__aside { width: 128px; height: calc(100% - 119px); background-color: #524F4E; position: absolute; bottom: 0; right: 0; background-image: url(../img/common/ico_arrow_down_white.svg); background-repeat: no-repeat; background-position: center bottom 50px; writing-mode: vertical-lr; font-size: 11px; font-weight: bold; color: #FFFFFF; display: flex; align-items: center; box-sizing: border-box; padding: 100px 0 0 0; }

.home-kv__aside span { opacity: 0.6; }

@media screen and (max-width: 768px) { .home-kv__aside { width: auto; position: relative; bottom: inherit; background-image: none; writing-mode: inherit; text-align: center; padding: 0; display: block; background-color: inherit; margin: 0 0 40px 0; } }

.home-kv__date { position: absolute; left: 50px; bottom: 50px; color: #fff; font-weight: bold; font-size: 38px; line-height: 1.1; text-transform: uppercase; }

@media screen and (max-width: 768px) { .home-kv__date { display: none; } }

.home-kv__text { position: absolute; top: 0; left: 0; width: 50vw; height: 100vh; color: #fff; font-size: 18px; font-weight: bold; text-align: center; line-height: 1.6; display: flex; align-items: center; justify-content: center; flex-direction: column; }

.home-kv__text em { font-size: 14px; font-style: normal; opacity: 0.6; }

@media screen and (max-width: 768px) { .home-kv__text em { font-size: 12px; } }

@media screen and (max-width: 768px) { .home-kv__text { position: relative; width: 100%; height: auto; font-size: 16px; margin: 30px 0 60px 0; } }

.home-kv__title { font-size: 11px; font-weight: bold; color: #fff; opacity: 0.6; position: absolute; left: 50px; top: 0; writing-mode: vertical-rl; text-align: center; height: 100%; transform: rotate(180deg); }

@media screen and (max-width: 768px) { .home-kv__title { position: relative; left: 0; height: auto; writing-mode: inherit; transform: inherit; } }

.tag-cloud { margin: 80px 50px 70px 50px; display: flex; flex-wrap: wrap; }

.shares-main .tag-cloud { margin-bottom: 0; }

@media screen and (max-width: 768px) { .tag-cloud { margin: 60px 20px 50px 20px; } }

.tag-cloud a { font-size: 31px !important; font-weight: bold; color: #646B64; margin: 0 20px 10px 0; transition: 0.5s; }

@media screen and (max-width: 768px) { .tag-cloud a { font-size: 20px !important; } }

.tag-cloud a:hover { color: #D1C4A8; }

.tag-cloud a::before { content: '#'; }

.shares-header { display: flex; align-items: center; }

@media screen and (max-width: 768px) { .shares-header { flex-direction: column; position: relative; padding: 85px 0 0 0; } }

.shares-header__img { margin: 0; padding: 0; display: block; transition: 0.5s; width: 67%; }

@media screen and (max-width: 768px) { .shares-header__img { width: 100%; margin: 0 0 20px 0; } }

.shares-header__img:hover { opacity: 0.75; }

.shares-header__img img { width: 100%; height: auto; }

.shares-header__text { box-sizing: border-box; padding: 0 0 0 40px; width: 33%; }

@media screen and (max-width: 768px) { .shares-header__text { width: 100%; padding: 0; } }

.shares-header__title { margin: 0 0 75px 0; font-size: 60px; font-weight: bold; color: #333333; }

@media screen and (max-width: 768px) { .shares-header__title { font-size: 38px; position: absolute; top: 0; left: 0; margin: 0; } }

.shares-header__link { margin: 0 0 14px 0; font-size: 22px; font-weight: bold; color: #FFFFFF; line-height: 1.4; transition: 0.5s; display: block; }

@media screen and (max-width: 768px) { .shares-header__link { font-size: 18px; } }

.shares-header__link:hover { opacity: 0.75; }

/* Masonryのレイアウト用CSS */
/* 親コンテナ */
.masonry-wrapper { width: 100%; box-sizing: border-box; margin: 80px -20px; }

@media screen and (max-width: 768px) { .masonry-wrapper { margin: 60px 0; } }

/* 2. 子アイテム (共通設定) */
.masonry-item { box-sizing: border-box; /* widthとpaddingを正しく計算するため */ /* アイテム間の隙間 (左右 20px + 20px = 40px) */ padding-left: 20px; padding-right: 20px; /* アイテムの下の隙間 (40px) */ margin-bottom: 40px; width: 33.333%; }

@media screen and (max-width: 768px) { .masonry-item { width: 50%; } }

@media screen and (max-width: 499px) { .masonry-item { width: 100%; padding-left: 0; padding-right: 0; } }

.masonry-item__title { display: block; margin: 20px 0 15px 0; font-size: 18px; font-weight: bold; color: #fff; transition: 0.5s; }

.masonry-item__title:hover { opacity: 0.75; }

.post-thumbnail a { transition: 0.5s; }

.post-thumbnail a:hover { opacity: 0.75; }

.post-thumbnail a img { width: 100%; height: auto; }

/* --- ニュースセクション全体 --- */
.news-section { max-width: 1100px; margin: 0 auto; padding: 0 0 130px 0; }

.news-section h2 { font-size: 3rem; font-weight: bold; color: #333333; margin-bottom: 48px; text-align: center; }

/* --- ニュースコンテンツ (PC) --- */
.news-content { display: grid; grid-template-columns: 1fr 2fr; gap: 50px; align-items: center; }

/* --- PC版: 左カラム (ビジュアル) --- */
.news-visual-wrapper { width: 100%; }

.news-visual { position: relative; width: 100%; padding-top: 100%; border-radius: 50%; overflow: hidden; background-color: #333; }

.news-visual .news-image { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 0.4s ease; transform: scale(1); }

.news-visual .news-image.active { opacity: 1; }

.news-pagination { text-align: center; font-size: 1rem; color: #ccc; margin-top: 20px; letter-spacing: 1px; }

/* --- PC版: 右カラム (記事リスト) --- */
.news-list-wrapper { display: flex; flex-direction: column; }

.news-list { list-style: none; padding: 0; margin: 0; }

.news-item { border-bottom: 1px solid #777; }

.news-item a { display: flex; justify-content: space-between; align-items: center; padding: 24px 10px; transition: background-color 0.3s ease; }

.news-item a:hover { background-color: rgba(255, 255, 255, 0.05); }

/* モバイル用の画像・番号はPCでは非表示 */
.news-item-visual-sp, .news-item-number-sp { display: none; }

.news-item-content h3 { font-size: 1.1rem; font-weight: bold; margin: 0 0 10px 0; line-height: 1.6; }

.news-meta { font-size: 0.9rem; color: #ccc; }

.news-meta time { margin-right: 15px; }

.news-tags { font-size: 0.9rem; color: #646B64; margin-top: 12px; }

.news-item-arrow { font-size: 1.5rem; color: #999; transition: transform 0.3s ease; }

.news-item a:hover .news-item-arrow { transform: translateX(5px); }

.view-more-wrapper { margin-top: 70px; text-align: center; }

/* --- View More リンク (PC) --- */
.view-more-link { display: inline-block; padding-bottom: 5px; border-bottom: 1px solid #f0f0f0; font-size: 1rem; transition: opacity 0.3s ease; }

.view-more-link:hover { opacity: 0.7; }

@media screen and (max-width: 768px) { .news-section { padding: 0 40px 60px 40px; }
  .news-section h2 { font-size: 2.5rem; margin: 0 0 20px 0; }
  /* 1カラムレイアウト */
  .news-content { grid-template-columns: 1fr; gap: 30px; }
  /* PC版の左カラム（画像切り替えエリア）は非表示に */
  .news-visual-wrapper { display: none; }
  /* 記事リスト (aタグ) をモバイルデザインのレイアウトに変更 */
  .news-item a { display: grid; grid-template-columns: 150px 1fr; /* 左:画像, 右:テキスト */ gap: 15px; align-items: flex-start; /* 上揃え */ padding: 28px 0; }
  .news-item a:hover { background-color: transparent; /* ホバーエフェクト無効 */ }
  /* JSで挿入されるモバイル用画像を表示 */
  .news-item-visual-sp { display: block; width: 150px; height: 150px; border-radius: 50%; overflow: hidden; background-color: #333; }
  .news-item-visual-sp img { width: 100%; height: 100%; object-fit: cover; }
  /* JSで挿入される番号を表示 */
  .news-item-number-sp { display: block; font-size: 0.9rem; font-weight: bold; color: #f0f0f0; margin-bottom: 8px; }
  .news-item-content h3 { font-size: 1rem; margin-bottom: 8px; }
  .news-meta { font-size: 0.85rem; color: #ccc; }
  .news-tags { font-size: 0.85rem; margin-top: 10px; color: #f0c040; /* モバイルデザインの黄色いタグ */ }
  /* PC版の矢印は非表示 */
  .news-item-arrow { display: none; }
  .view-more-wrapper { margin-top: 30px; text-align: center; } }

@media screen and (max-width: 499px) { .news-section { padding: 0 20px 60px 20px; }
  .news-section h2 { text-align: left; } }

:root { --column-bg-color: #F5F4E9; /* 背景色 */ --column-text-black: #333333; --column-text-gray: #999999; --column-card-bg: #FFFFFF; }

/* --- 📱 モバイルレイアウト (デフォルト設定) --- */
/* 📌 column-sectionに背景色と上下のpaddingを適用 */
.column-section { background-color: var(--column-bg-color); padding-top: 80px; padding-bottom: 80px; }

.column-container { width: calc(100% - 20px); max-width: 1400px; margin: 0 auto; padding-left: 20px; }

/* ヘッダーエリア */
.column-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 30px; padding-right: 20px; /* 右側の余白 */ }

.column-title { font-size: 2.8rem; font-weight: 700; letter-spacing: 0.05em; color: #3A3A3A; font-family: 'Helvetica', sans-serif; }

/* モバイルでは上部の "View More" とページネーションは非表示 */
.column-view-more-top, .column-slider-controls { display: none; }

/* --- スライダー本体 --- */
.column-swiper { width: 100%; }

/* --- カードデザイン (前回と同じ) --- */
.column-card { background-color: var(--column-card-bg); width: 100%; display: flex; flex-direction: column; transition: 0.5s; }

.column-card:hover { opacity: 0.75; }

.column-image-wrapper { width: 100%; height: 200px; overflow: hidden; }

.column-image-wrapper img { width: 100%; height: 100%; object-fit: cover; }

.column-card-content { position: relative; padding: 40px 20px 30px; text-align: center; }

/* アバターアイコン */
.column-avatar { position: absolute; top: -30px; left: 50%; transform: translateX(-50%); width: 60px; height: 60px; background: #fff; border-radius: 50%; padding: 3px; }

.column-avatar img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; border: 1px solid #eee; }

/* テキストスタイル */
.column-author-info { margin-bottom: 10px; font-family: 'Helvetica', sans-serif; }

.column-author-name { display: block; font-weight: 700; font-size: 0.85rem; margin-bottom: 2px; color: #333333; }

.column-post-date { font-size: 0.75rem; color: var(--column-text-gray); }

.column-card-title { font-size: 1rem; font-weight: 700; margin-bottom: 15px; line-height: 1.7; text-align: left; color: #333; }

.column-tags { display: flex; flex-wrap: wrap; gap: 5px; justify-content: flex-start; }

.column-tag { font-size: 13px; color: #aaa; font-style: italic; }

/* --- モバイル版 View More (下部) --- */
.column-view-more-bottom { display: flex; justify-content: center; padding: 40px 0 0; width: 100%; }

.column-view-more-link { font-size: 1rem; font-weight: 500; border-bottom: 1px solid var(--column-text-black); padding-bottom: 2px; display: inline-flex; align-items: center; gap: 8px; transition: opacity 0.3s; color: #333; }

.column-view-more-link:hover { opacity: 0.7; }

/* --- 💻 デスクトップ対応 (Min-width: 1024px) --- */
@media (min-width: 1024px) { .column-swiper { padding-bottom: 50px !important; }
  /* 📌 column-sectionのpaddingをPCサイズに調整 */
  .column-section { padding-top: 100px; padding-bottom: 100px; }
  /* レイアウトと余白の調整 */
  .column-container { width: 92%; max-width: 1400px; padding-left: 4%; }
  /* ヘッダーエリア */
  .column-header { align-items: flex-end; margin-bottom: 40px; padding-right: 4%; }
  .column-title { font-size: 4rem; }
  /* PCでは下部のView Moreを非表示にし、上部の要素を表示 */
  .column-view-more-bottom { display: none; }
  .column-view-more-top { display: inline-flex; font-size: 0.9rem; font-weight: 500; border-bottom: 1px solid #333333; padding-bottom: 2px; align-items: center; gap: 8px; margin: 0 0 0 40px; color: #333333; }
  .column-header-left { display: flex; align-items: baseline; }
  /* PC用スライダーコントロールの表示 */
  .column-slider-controls { display: flex; align-items: center; gap: 20px; font-family: 'Helvetica', sans-serif; font-size: 1rem; }
  .column-nav-arrow { cursor: pointer; font-size: 1.2rem; color: #666; user-select: none; transition: color 0.3s; }
  .column-nav-arrow:hover { color: var(--column-text-black); }
  .column-custom-pagination { font-variant-numeric: tabular-nums; letter-spacing: 2px; color: #333; }
  /* カードのサイズ・ホバー効果をPC用に調整 */
  .column-card { width: 100%; }
  .column-image-wrapper { height: 250px; }
  .column-card-content { padding: 50px 30px 40px; }
  .column-card:hover .column-card-image { transform: scale(1.05); } }

/* パララックス（視差効果）セクション */
.parallax-hero { /* ここに背景画像のパスを指定してください */ background-image: url("https://sonslike.com/wp/wp-content/uploads/2026/01/bg_parallax-scaled-1.jpg"); /* パララックス効果の核となる記述 */ background-attachment: fixed; background-position: center; background-repeat: no-repeat; background-size: cover; padding: 160px 20px 60px 20px; /* コンテンツを中央寄せにするFlexbox設定 */ display: flex; justify-content: center; align-items: center; text-align: center; /* 画像を少し暗くして文字を見やすくする場合のオーバーレイ（任意） */ position: relative; }

@media screen and (max-width: 499px) { .parallax-hero { padding: 80px 20px; } }

/* テキストコンテナ */
.content-wrapper { position: relative; z-index: 2; /* オーバーレイの上に表示 */ }

/* メイン見出し */
.main-title { font-size: 26px; font-weight: bold; margin-bottom: 1.5rem; letter-spacing: 0.02em; }

/* 繰り返しテキスト */
.sub-text-group { font-size: 16px; line-height: 1.6; font-weight: 500; text-shadow: 0 1px 5px rgba(0, 0, 0, 0.3); }

.sub-text-group p { margin-bottom: 0.2rem; }

/* 最初の行だけ少し長いテキストを再現 */
.sub-text-group p:first-child { margin-bottom: 0.5rem; }

/* メインコンテナ（背景部分） */
.hero-section { position: relative; }

/* パンくずリスト (左上) */
.breadcrumbs { color: #ffffff; font-size: 13px; }

.breadcrumbs a { color: #ffffff; text-decoration: none; }

/* パンくずリストの区切り文字 (>) の余白 */
.breadcrumbs .separator { margin: 0 5px; }

/* メインタイトル (Columns) */
.main-title-under { color: #ffffff; font-size: 60px; font-weight: 700; line-height: 1.3; letter-spacing: 2px; margin: 80px 0; }

.shares-main .main-title-under { margin-bottom: 0; }

/* レスポンシブ対応（スマホなどの小さい画面用） */
@media (max-width: 768px) { .main-title-under { font-size: 36px; } }

/* ページネーション全体のコンテナ */
.custom-pagination { margin-top: 60px; /* Masonryとの余白 */ margin-bottom: 60px; /* 下のセクションとの余白 */ padding: 20px 0; border-top: 1px solid rgba(255, 255, 255, 0.2); /* 上の線（薄い白） */ border-bottom: 1px solid rgba(255, 255, 255, 0.2); /* 下の線（薄い白） */ display: flex; justify-content: center; font-family: sans-serif; /* フォント指定（サイトに合わせて調整） */ }

/* リストのスタイルリセット */
.custom-pagination ul { display: flex; align-items: center; list-style: none; padding: 0; margin: 0; gap: 10px; /* 数字同士の間隔 */ }

.custom-pagination li { margin: 0; }

/* 数字のリンクとスパン共通設定 */
.custom-pagination a, .custom-pagination span { display: flex; align-items: center; justify-content: center; text-decoration: none; font-size: 16px; color: #fff; /* 文字色：白 */ width: 40px; height: 40px; border-radius: 50%; /* 丸くする */ transition: all 0.3s ease; }

/* ホバー時のスタイル */
.custom-pagination a:hover { background-color: rgba(255, 255, 255, 0.1); }

/* 現在のページ（黒い丸） */
.custom-pagination .current { background-color: #333; /* 背景色：濃いグレー/黒 */ color: #fff; font-weight: bold; cursor: default; }

/* 「次へ」ボタン（四角い黒い箱） */
.custom-pagination .next { border-radius: 0; /* 丸みをなくす */ background-color: #222; /* 背景色：黒 */ color: #fff; width: 50px; height: 50px; margin-left: 20px; /* 数字との間隔を少し広げる */ font-size: 24px; /* 矢印のサイズ */ line-height: 1; }

.custom-pagination .next:hover { background-color: #000; }

/* 矢印の微調整 */
.pagination-arrow { display: inline-block; transform: translateY(-2px); /* 垂直位置の微調整 */ font-size: 32px !important; line-height: 1; }

/* 省略記号（...） */
.custom-pagination .dots { border-radius: 0; width: auto; padding: 0 5px; }
