@charset "UTF-8";
/* -------------------------------------------------------
component
---------------------------------------------------------- */
.c-global-icons { background-image: url(/common/otp/images/v1/common/global-icons-blue.png?rd=20180601); background-repeat: no-repeat; background-size: 24px 288px; display: inline-block; height: 24px; width: 24px; cursor: pointer; overflow: hidden; white-space: nowrap; text-indent: 150%; -webkit-box-sizing: border-box; box-sizing: border-box; }
.c-global-icons--fb { width: 24px; background-position: 0 0; }
.c-global-icons--tw { width: 24px; background-position: 0 -48px; }
.c-global-icons--menu { background-position: 0 -96px; }
.c-global-icons--search { background-position: 0 -144px; }
.c-global-icons--regist { background-position: 0 -193px; }
.c-global-icons--login { background-position: 0 -239px; }
.c-heading { color: #595959; font-weight: normal; font-size: 20px; line-height: 23px; margin: 0.5em 0; border-bottom: solid 1px #00448b; padding-bottom: 0.3em; }
.c-more-link { text-align: right; font-size: 12px; margin-top: 10px; clear: both; }
.c-more-link > a { color: #00448b; }
.c-date { color: #979797; font-size: 12px; display: block; }
/* キーワード、タグ(トップ「Topics」,記事下キーワード,右カラム「注目のまとめ＆トピックス」共通) */
.c-tags { overflow: hidden; font-size: 0; }
.c-tag { display: inline-block; margin-right: 5px; margin-bottom: 5px; color: #4F77A6; background-color: #fff; border: 1px solid #b9cbde; border-radius: 2px; font-size: 13px; padding: 0.3em 10px; }
.c-tag:hover { text-decoration: none; background-color: #b9cbde; color: #fff; }
/* アイコン(16:9) */
.c-icon { width: 100%; padding-top: 56.25%; position: relative; background-color: #f1f1f1; display: block; }
.c-icon img { position: absolute; top: 0; left: 0; bottom: 0; right: 0; margin: auto; max-height: 100%; max-width: 100%; }
/* プレミアムマーク */
.c-premium-mark { background: url(/common/otp/images/v1/common/premium-icon.png) no-repeat left; background-size: 18px 18px; color: #0086c2; display: inline-block; font-size: 11px; font-weight: bold; height: 18px; margin-left: 10px; padding-left: 20px; vertical-align: middle; line-height: 18px; }
/* 検索 */
.c-search-box { border-bottom: solid 1px #5c9ebb; background-color: #fff; width: 500px; margin: 0 auto 10px; font-size: 0; }
.c-search-box__text { width: 460px; padding: 10px 5px; }
.c-search-box__btn { width: 20px; height: 20px; display: inline-block; text-indent: 300%; white-space: nowrap; overflow: hidden; background: url(/common/otp/images/v1/common/search-icon.png) no-repeat; background-size: 20px 20px; cursor: pointer; }
/* -------------------------------------------------------
parts > header
---------------------------------------------------------- */
/* ハンバーガーメニュー */
.header-menu { background: #fff; z-index: 990; position: fixed; top: 0; left: -100%; bottom: 0; width: 200px; -webkit-box-shadow: 1px 0px 2px 1px #eee; box-shadow: 1px 0px 2px 1px #eee; }
.header-menu-unit { margin: 0; padding: 0; }
.header-menu-unit__list { position: relative; list-style: none; }
.header-menu-unit__list > a { display: block; height: 44px; position: relative; padding: 0 10px; font-size: 14px; color: #00448b; line-height: 44px; curspr: pointer; }
.header-menu-unit__list > a::after, .header-menu-unit__list > a::before { position: absolute; top: 0; bottom: 0; right: 20px; margin: auto; content: ""; vertical-align: middle; }
.header-menu-unit__list > a::before { width: 8px; height: 8px; border-top: 1px solid #ccc; border-right: 1px solid #ccc; -webkit-transform: rotate(45deg); transform: rotate(45deg); }
.header-menu-unit__list--select a, .header-menu-unit__list--select span.title, .header-menu-unit__list a:hover, .header-menu-unit__list span.title:hover { background: #0086c2; color: #fff; text-decoration: none; cursor: pointer; }
.header-menu-subunit-wrap { display: none; position: absolute; top: -5px; left: 180px; z-index: 995; width: 200px; }
.header-menu-subunit { position: relative; padding: 10px 0px; background: #fff; border: solid 2px #eee; border-radius: 4px; }
.header-menu-subunit::before { border: 15px solid transparent; border-right-color: #fff; border-left-width: 0; left: -12px; content: ""; display: block; top: 10px; position: absolute; width: 0; z-index: 1; }
.header-menu-subunit::after { border: 15px solid transparent; border-right-color: #eee; border-left-width: 0; left: -15px; content: ""; display: block; top: 10px; position: absolute; width: 0; }
.header-menu-subunit__list { display: block; padding: 0 10px; }
.header-menu-subunit__list > a { font-size: 13px; padding: 5px; height: auto; line-height: 1.4; color: #00448b; display: block; }
.header-menu-subunit__list > a:hover { background: #fff; text-decoration: underline; color: #00448b; }
/* ヘッダ上部 */
.header-top { padding: 8px 0; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; width: 1058px; margin: 0 auto; }
.header-top-logo { width: 220px; margin: 0 auto; text-align: center; font-size: 0; }
.header-top-navi { width: calc((100% - 220px) / 2); }
.header-top-navi__date { color: #666; font-size: 14px; padding-top: 10px; clear: both; }
.header-top-navi__menu { padding-left: 30px; float: left; }
.header-top-navi__search { float: left; border-bottom: 1px solid #b9cbde; width: 190px; margin-left: 10px; }
.header-top-navi__search input { -webkit-appearance: none; -moz-appearance: none; appearance: none; border-style: none; background: transparent; }
.header-top-navi__search input.inputtext { padding: 0.3em; width: 160px; }
.header-top-navi__search input.search-btn { background-color: #002042; width: 20px; height: 20px; display: inline-block; text-indent: 400%; white-space: nowrap; overflow: hidden; background: url(/common/otp/images/v1/common/search-icon.png) no-repeat; background-size: 16px; background-position: top 3px right 3px; cursor: pointer; float: right; border-radius: 0 4px 4px 0; }
.header-top-subnavi { width: calc((100% - 220px) / 2); text-align: right; }
.header-top-links { margin-bottom: 5px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: reverse; -ms-flex-direction: row-reverse; flex-direction: row-reverse; }
.header-top-links__snslink { display: inline-block; margin-left: 12px; }
.header-top-links__btn { margin-left: 5px; padding: 0.3em 0.5em; border-radius: 4px; font-size: 12px; }
.header-top-links__btn--login { margin-left: 12px; }
.header-top-links__btn--blue { background-color: #00448b; color: #fff; border: 1px solid #00448b; }
.header-top-links__btn--blue:hover { background-color: #fff; color: #00448b; text-decoration: none; }
.header-top-links__btn--orange { background-color: #faa634; color: #fff; border: 1px solid #faa634; }
.header-top-links__btn--orange:hover { background-color: #fff; color: #faa634; text-decoration: none; }
.header-top-info { border: 1px solid #00448b; color: #00448b; padding: 0.3em 0.5em; border-radius: 4px; font-size: 12px; display: inline-block; }
.header-top-info:hover { text-decoration: none; }
.header-top-companyinfo { display: inline-block; -webkit-margin-before: 0em; -webkit-margin-after: 0em; margin: 0; }
.header-top-companyinfo:hover .header-top-companyinfo__unit { visibility: visible; }
.header-top-companyinfo__unit { visibility: hidden; position: relative; }
.header-top-companyinfo__title { position: relative; padding-right: 22px; color: #00448b; margin-top: 8px; cursor: pointer; font-size: 12px; }
.header-top-companyinfo__title::after { content: ""; display: block; width: 0; height: 0; border-left: 4px solid transparent; border-right: 4px solid transparent; border-top: 6px solid #00448b; position: absolute; top: 0.3em; right: 0.7em; }
.header-top-companyinfo-list { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; position: absolute; overflow: hidden; top: 0; right: 0; width: 400px; -webkit-box-sizing: border-box; box-sizing: border-box; background-color: #fff; border: 1px solid #00448b; max-height: 250px; padding: 0.5em 2em 0.5em 1em; z-index: 1; }
.header-top-companyinfo-list__link { -ms-flex-preferred-size: calc(50% - 1em); flex-basis: calc(50% - 1em); padding-left: 1em; font-size: 13px; line-height: 2; color: #00448b; text-align: left; display: block; }
/* サイトナビ */
.header-sitenavi { margin-bottom: 10px; min-height: 56px; }
.header-sitenavi-main { background: #0086c2; }
.header-sitenavi-main-unit { display: -webkit-box; display: -ms-flexbox; display: flex; list-style: none; }
.header-sitenavi-main-unit__link { display: block; vertical-align: middle; text-align: center; -webkit-box-sizing: border-box; box-sizing: border-box; width: 130px; font-size: 14px; font-weight: bold; color: #fff; background: #0086c2; padding: 6px 0; position: relative; }
.is-active .header-sitenavi-main-unit__link, .header-sitenavi-main-unit__link:hover { background: #00448b; text-decoration: none; }
.is-active .header-sitenavi-main-unit__link:after, .header-sitenavi-main-unit__link:hover:after { content: ""; display: block; width: 0; height: 0; border-left: 4px solid transparent; border-right: 4px solid transparent; border-bottom: 4px solid #f0f4f8; position: absolute; bottom: 0; left: calc(50% - 2px); }
.header-sitenavi-sub { max-height: 28px; background: #f0f4f8; overflow: hidden; }
.header-sitenavi-sub-unit { margin: 0; padding: 0; display: -webkit-box; display: -ms-flexbox; display: flex; list-style: none; }
.header-sitenavi-sub-unit__link { font-size: 13px; color: #00448b; padding: 6px 10px; display: block; }
/* サイトナビ スクロール後 */
.header-second { background: #fff; color: #00448b; border-bottom: 1px solid #00448b; padding: 12px 0; font-size: 12px; text-align: center; position: relative; display: none; overflow: hidden; position: fixed; left: 0px; top: 0px; width: 100%; z-index: 11; }
.header-second-unit { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.header-second-main { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; width: 350px; }
.header-second-main__menu { margin-right: 8px; }
.header-second-main__logo { width: 150px; }
.header-second-main__logo img { width: 100%; display: block; }
.header-second-main__search { border-bottom: none; width: 150px; margin-left: 10px; background-color: #f0f4f8; }
.header-second-main__search input { -webkit-appearance: none; -moz-appearance: none; appearance: none; border-style: none; background: transparent; }
.header-second-main__search .inputtext { padding: 0.3em; width: 120px; -webkit-box-sizing: border-box; box-sizing: border-box; }
.header-second-main__search .search-btn { background-color: #002042; width: 20px; height: 20px; display: inline-block; text-indent: 400%; white-space: nowrap; overflow: hidden; background: url(/common/otp/images/v1/common/search-icon.png) no-repeat; background-size: 16px; background-position: top 3px right 3px; cursor: pointer; float: right; border-radius: 0 4px 4px 0; }
.header-second-sub { margin-left: 20px; width: 130px; display: -webkit-box; display: -ms-flexbox; display: flex; }
.header-second-sub__link { line-height: 24px; margin-left: 8px; }
.header-second-category { width: 568px; display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.header-second-category__link { display: inline-block; line-height: 24px; font-size: 14px; margin-left: 20px; color: #00448b; }
/* ニックネーム */
.header-nickname { display: inline-block; font-size: 12px; line-height: 13px; padding-top: 0.5em; }
/* -------------------------------------------------------
parts > footer
---------------------------------------------------------- */
.footer-menu { background: #0086c2; color: #fff; }
.footer-menu a { color: #fff; }
.footer-menu-head { padding-top: 20px; }
.footer-menu-search { float: left; border-bottom: solid 1px #5c9ebb; background-color: #fff; width: 300px; }
.footer-menu-search__inputtext { padding: 10px 5px; width: 260px; }
.footer-menu-search__btn { width: 20px; height: 20px; display: inline-block; text-indent: 200%; white-space: nowrap; overflow: hidden; background: url(/common/otp/images/v1/common/search-icon.png) no-repeat; background-size: 20px 20px; cursor: pointer; }
.footer-menu-icons { float: right; display: -webkit-box; display: -ms-flexbox; display: flex; }
.footer-menu-icons__item { width: 36px; height: 36px; text-indent: 150%; overflow: hidden; white-space: nowrap; display: block; background-image: url(/common/otp/images/v1/common/global-icons.png?rd=20160801); background-repeat: no-repeat; background-size: 36px 432px; margin-left: 20px; }
.footer-menu-icons__item--fb { background-position: 0 0; }
.footer-menu-icons__item--tw { background-position: 0 -71px; }
.footer-menu-icons__item--regist { background-position: 0 -288px; }
.footer-menu-icons__item--login { background-position: 0 -358px; }
.footer-menu-wrap { padding: 40px 0; width: 100%; overflow: hidden; -webkit-box-sizing: border-box; box-sizing: border-box; display: -webkit-box; display: -ms-flexbox; display: flex; margin-left: -20px; }
.footer-menu-list { margin: 0 0 0 20px; padding: 0; }
.footer-menu-list__item { list-style: none; font-size: 14px; padding: 5px 0 5px 10px; border-left: solid 1px #fff; margin-left: 15px; white-space: nowrap; }
.footer-menu-list__item--category { margin: 15px 0; font-weight: bold; border: none; }
.footer-area47news { padding: 20px 0 10px; }
.footer-area47news-heading { margin: 0 0 10px 0; color: #666; font-size: 13px; font-weight: bold; }
.footer-area47news-list { margin: 0; padding: 0; overflow: hidden; list-style: none; font-size: 0; }
.footer-area47news-list__item { font-size: 12px; padding: 0 10px 0 9px; margin: 0 0 10px; float: left; border-right: solid 1px #666; text-align: justify; color: #666; }
.footer-copy { background: #00448b; text-align: center; padding: 20px 0; color: #fff; }
.footer-copy__logo { margin-bottom: 10px; }
.footer-copy__text { color: #acccee; font-size: 11px; margin: 5px; }
/* PAGE TOP */
.footer-fixed-btns { position: fixed; right: 30px; bottom: 70px; -webkit-transition: .3s; transition: .3s; display: none; }
.footer-fixed-btns__top { width: 40px; height: 50px; background: url(/common/otp/images/v1/common/icon-backto-pagetop.png) no-repeat center center; background-size: 40px 50px; cursor: pointer; opacity: .8; }
.footer-fixed-btns__top:hover { opacity: .8; }
.footer-fixed-btns__home { width: 40px; height: 50px; background: url(/common/otp/images/v1/common/icon-backto-home.png) no-repeat center center; background-size: 40px 50px; cursor: pointer; margin-bottom: 10px; opacity: .8; }
.footer-fixed-btns__home:hover { opacity: .8; }
/* -------------------------------------------------------
sub-column (scはSubColumnの意味)
---------------------------------------------------------- */
/* 購読お申し込み */
.subscription { margin-bottom: 30px; overflow: hidden; }
.subscription a:hover { text-decoration: none; }
.subscription__cover { float: left; width: 100px; margin-top: 5px; }
.subscription__cover > img { width: 100%; }
.subscription__cover-caption { font-size: 12px; text-align: center; display: block; color: #666; }
.subscription__links { float: right; width: 180px; }
.subscription__btn { border-radius: 4px; color: #fff; background-color: #0086c2; display: block; text-align: center; padding: 8px 5px; line-height: 1.4; margin-top: 10px; }
.subscription__btn--blue { background-color: #00448b; }
.subscription__btn--about { background-image: url(/common/otp/images/v1/common/icon-beginner.png); background-repeat: no-repeat; background-position: left 36px top 50%; background-size: 14px; padding-left: 18px; }
/* ランキング */
.sc-ranking-tab { border-bottom: 6px solid #00448b; }
.sc-ranking-tab__item { cursor: pointer; color: #45a3cf; display: inline-block; font-size: 14px; padding: 10px; }
.sc-ranking-tab__item.is-active { color: #00448b; }
.sc-ranking-unit:nth-of-type(2n+1) { display: none; }
.sc-ranking-list { margin: 0; padding: 0; }
.sc-ranking-list:nth-of-type(2n+1) { display: none; }
.sc-ranking-unit-tab { display: -webkit-box; display: -ms-flexbox; display: flex; }
.sc-ranking-unit-tab__item { color: #00448b; font-size: 12px; padding: 10px; width: 50%; -webkit-box-sizing: border-box; box-sizing: border-box; border-right: 2px solid #00448b; cursor: pointer; display: block; background-color: #f0f4f8; }
.sc-ranking-unit-tab__item:last-child { border: 0px; }
.sc-ranking-unit-tab__item.is-active { background-color: #ffffff; }
.sc-ranking-list-item { border-bottom: 1px solid #ccc; display: block; list-style: outside none none; padding: 8px 0; width: 100%; overflow: hidden; color: #00448b; }
.sc-ranking-list-item a:hover { text-decoration: none; }
.sc-ranking-list-item a:hover .sc-ranking-list-item__text-title { text-decoration: underline; }
.sc-ranking-list-item__icon { width: 112px; height: 84px; position: relative; display: block; overflow: hidden; background-color: #f1f1f1; margin-right: 10px; float: left; }
.sc-ranking-list-item__icon > img { position: absolute; top: 0; left: 0; bottom: 0; right: 0; margin: auto; max-height: 100%; max-width: 100%; }
.sc-ranking-list-item__text { overflow: hidden; line-height: 1.4; color: #00448b; font-size: 14px; }
.sc-ranking-list-item__text-title { color: #00448b; }
/* ライン誘導枠 */
.sc-line { border-radius: 10px; background: #f6f6f6; padding: 20px 20px 0; margin-bottom: 20px; }
.sc-line-link { padding-bottom: 20px; text-align: center; }
.sc-line-link__title { margin-bottom: 10px; font-size: 14px; line-height: 1.4; }
.sc-line-link__btn { margin-bottom: 10px; }
.sc-line-link__name { font-size: 14px; line-height: 1.4; font-weight: bold; }
/* PR */
.sc-pr { padding-left: 10px; }
.sc-pr-link { color: #00448b; font-size: 13px; margin-bottom: 4px; display: block; }
/* -------------------------------------------------------
parts > ad
---------------------------------------------------------- */
.ad-topbanner { text-align: center; }
/* ページ下 */
.ad-bottom-banner { width: 920px; margin: 0 auto 60px; min-height: 60px; }
.ad-bottom-banner-list { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-left: -40px; font-size: 0; padding: 0; }
.ad-bottom-banner-list__item { width: 120px; background-color: #eee; margin-left: 40px; font-size: 12px; list-style: none; }
/* footer下 */
.ad-footer-banner { text-align: center; padding-bottom: 40px; }
/* -------------------------------------------------------
parts > media-news トップ・記事下で使用する同一パーツのスタイル
---------------------------------------------------------- */
/* Top News */
.media-top-news { margin-bottom: 30px; }
.media-top-news-item { padding-top: 8px; display: block; overflow: hidden; }
.media-top-news-item:hover { text-decoration: none; }
.media-top-news-item:hover .media-top-news-item__text-title { text-decoration: underline; }
.media-top-news-item__photo { float: right; width: 160px; margin: 0 0 0 10px; }
.media-top-news-item__photo > img { width: 100%; vertical-align: bottom; }
.media-top-news-item__text-title { font-weight: normal; color: #00448b; font-size: 18px; line-height: 1.4; margin: 0; }
.media-top-news-item__text-date { font-size: 12px; color: #666; margin: 5px 0 15px; }
.media-top-news-item__text-summary { color: #666; line-height: 1.6; font-size: 14px; }
.media-top-news-more { border-top: solid 1px #ccc; }
/* Topics */
.media-topics { margin-bottom: 30px; overflow: hidden; }
.media-topics-heading { float: left; padding-left: 23px; padding-right: 5px; font-size: 12px; font-weight: bold; left: 0; top: 0; color: #66b6da; position: relative; }
.media-topics-heading::before { content: ""; position: absolute; left: 0; top: 0; display: inline-block; background: url(/common/otp/images/v1/common/topics-icon.png) no-repeat left; width: 18px; height: 18px; }
/* トップコラム */
.media-column { margin-bottom: 30px; }
.media-column-heading a { font-size: 14px; padding-left: 1em; }
/* 連載(スライダー) */
.top-series { margin: 20px 0 30px; }
.series-unit { position: relative; }
.series-unit__prev, .series-unit__next { width: 32px; height: 32px; display: block; background-size: 32px 32px; -webkit-background-size: 32px 32px; -moz-background-size: 32px 32px; background-repeat: no-repeat; text-indent: 150%; overflow: hidden; white-space: nowrap; z-index: 8; position: absolute; margin: auto; top: 0; bottom: 0; cursor: pointer; }
.series-unit__prev { background-image: url(/common/otp/images/v1/common/photo-arrow-prev.png); left: 5px; }
.series-unit__next { background-image: url(/common/otp/images/v1/common/photo-arrow-next.png); right: 5px; }
.series-gallery { margin: 0 auto; overflow: hidden; width: 100%; position: relative; -webkit-box-sizing: content-box; box-sizing: border-box; }
.series-slider { position: relative; left: 0; top: 0; margin: 0; padding: 0; }
.series-item { float: left; list-style: none; margin-right: 20px; width: 150px; display: block; }
.series-item:hover { text-decoration: underline; }
.series-item__icon { width: 100%; }
.series-item__icon > img { margin: auto; width: 100%; -webkit-box-shadow: 0 9px 12px -9px #222; box-shadow: 0 9px 12px -9px #222; }
.series-item__title { padding: 0.5em 0 0 0; display: inline-block; line-height: 1.6; color: #00448b; font-size: 13px; }
/* 沖縄関連、今話題です（外部サイト） */
.nor-widget { margin: 20px 0 30px; }
/* -------------------------------------------------------
module > module
---------------------------------------------------------- */
/* 記事一覧(カテゴリ別、検索結果一覧など) */
.m-articles-v { margin: 0 0 30px 0; padding: 0; }
.m-articles-v-item { display: block; border-bottom: solid 1px #ccc; padding: 20px 0; }
.m-articles-v-item__icon { width: 150px; display: block; overflow: hidden; margin-right: 15px; float: left; }
.m-articles-v-item__text { overflow: hidden; }
.m-articles-v-item__text-title { font-size: 18px; line-height: 1.6; color: #00448b; display: block; }
.m-articles-v-item__text-date { font-size: 12px; color: #666; margin-bottom: 8px; display: inline-block; }
.m-articles-v-item__text-summary { color: #666; font-size: 14px; line-height: 1.4; margin: 5px 0 0; }
/* 記事一覧(正方形アイコン) */
.m-articles-v-small-item { overflow: hidden; display: block; border-bottom: solid 1px #ccc; padding: 8px 0; }
.m-articles-v-small-item__icon { width: 60px; height: 60px; position: relative; display: block; overflow: hidden; background-color: #f1f1f1; margin-right: 10px; float: left; }
.m-articles-v-small-item__icon--middle { width: 72px; height: 72px; background: none; }
.m-articles-v-small-item__icon > img { position: absolute; top: 0; left: 0; bottom: 0; right: 0; margin: auto; max-height: 100%; max-width: 100%; }
.m-articles-v-small-item__text { overflow: hidden; color: #00448b; font-size: 13px; line-height: 1.4; }
.m-articles-v-small-item__text-title--bold { font-weight: bold; margin-bottom: 3px; }
.m-articles-v-small-item__text-date { color: #979797; font-size: 12px; display: block; }
.m-articles-v-small-item__text-date--dark { color: #494949; margin-top: 5px; display: block; }
.m-articles-v-small--textonly .m-articles-v-small-item__text-date { display: inline; margin-left: 10px; }
.m-articles-v-small-item__text-column { display: block; text-align: right; font-size: 12px; }
.m-articles-v-small-item__text-author { display: block; color: #aaa; font-size: 12px; }
.m-articles-v-small-item__text--small { font-size: 12px; }
.m-articles-v-small-item__text--large { font-size: 15px; }
.m-articles-v-small-item__text--large-date { font-size: 14px; }
.m-articles-v-small-item:hover { text-decoration: none; }
.m-articles-v-small-item:hover .m-articles-v-small-item__text-title { text-decoration: underline; }
/* 記事一覧(記事下バックナンバーなどで使用) */
.m-articles-v-2cols { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 0; padding: 0; }
.m-articles-v-2cols-item { overflow: hidden; display: block; border-bottom: solid 1px #ccc; padding: 8px 0; margin: 0 8px; width: calc(50% - 16px); }
.m-articles-v-2cols-item__icon { width: 112px; height: 63px; position: relative; display: block; overflow: hidden; background-color: #f1f1f1; float: left; margin-right: 10px; }
.m-articles-v-2cols-item__icon > img { position: absolute; top: 0; left: 0; bottom: 0; right: 0; margin: auto; max-height: 100%; max-width: 100%; }
.m-articles-v-2cols-item__text { overflow: hidden; }
.m-articles-v-2cols-item__text-title { font-size: 15px; color: #00448b; line-height: 1.4; }
.m-articles-v-2cols-item:hover { text-decoration: none; }
.m-articles-v-2cols-item:hover .m-articles-v-2col-item__text-title { text-decoration: underline; }
/* 記事一覧(記事下Featureなどで使用) */
.m-articles { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 0 0 -15px 0; padding: 0; }
.m-articles-item { overflow: hidden; display: block; margin: 0 11px 15px 11px; width: calc(33% - 22px); }
.m-articles-item__icon { width: 210px; padding-top: 56.25%; position: relative; display: block; overflow: hidden; background-color: #f1f1f1; margin: 0 auto 5px; }
.m-articles-item__icon > img { position: absolute; top: 0; left: 0; bottom: 0; right: 0; margin: auto; max-height: 100%; max-width: 100%; }
.m-articles-item__text-title { font-size: 15px; color: #00448b; line-height: 1.4; }
.m-articles-item a:hover { text-decoration: none; }
.m-articles-item a:hover .m-articles-item__text-title { text-decoration: underline; }
.m-articles-item--2cols { margin: 0 9px 15px 9px; width: calc(50% - 18px); padding-bottom: 10px; border-bottom: 1px solid #ccc; }
.m-articles-item--2cols .m-articles-item__text-title { font-size: 14px; }
/* ページネーション */
.m-pagination { display: -webkit-box; display: -ms-flexbox; display: flex; margin-bottom: 30px; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; }
.m-pagination a { text-decoration: none; }
.m-pagination__item { display: block; width: 44px; height: 44px; border: solid 1px #4aa9d4; border-radius: 2px; line-height: 44px; background-color: #4aa9d4; color: #fff; text-decoration: none; margin: 0 5px; text-align: center; font-size: 14px; }
.m-pagination__item:hover, .m-pagination__item.is-current { background-color: #fff; color: #4aa9d4; }
.m-pagination__item--next, .m-pagination__item--prev { color: #4aa9d4; background: none; border: none; font-size: 14px; }
.m-pagination__item--next:hover, .m-pagination__item--prev:hover { text-decoration: underline; }
.m-pagination__item--next { margin-left: 12px; }
.m-pagination__item--prev { margin-right: 12px; }
.m-pagination__item--leader { color: #4aa9d4; background: none; border: none; line-height: 60px; margin: 0; }
/* パンくずリスト */
.m-breadcrumb { margin-bottom: 20px;  font-size: 12px; color: #666; line-height:1.6; }
.m-breadcrumb .m-breadcrumb__item a { color: #666; }
.m-breadcrumb .m-breadcrumb__item:after { content: ">"; font-size: 10px; color: #aaa; margin: 0 5px; vertical-align: top; }
.m-breadcrumb .m-breadcrumb__item:last-child:after  { content: none ; }
/* 表示件数 */
.m-articles-num { margin: 10px 0 20px; font-size: 16px; color: #333; }
/* -------------------------------------------------------
page-original > 記事ページ用
---------------------------------------------------------- */
/* 記事タイトル周り */
.article-header { margin-bottom: 30px; }
.article-header-cat { margin: 10px 0; }
.article-header-cat > a { font-size: 14px; margin: 10px 0; color: #666; line-height: 23px; position: relative; }
.article-header-cat > a::after { content: ""; display: inline-block; position: absolute; right: -1em; bottom: 0.25em; width: 8px; height: 8px; border-top: 1px solid #0086c2; border-right: 1px solid #0086c2; -webkit-transform: rotate(45deg); transform: rotate(45deg); }
.article-signage { background-position: right top; background-repeat: no-repeat; border-top: solid 1px #ddd; border-bottom: solid 1px #ddd; padding: 20px 0; overflow: hidden; }
.article-signage__ttl { font-size: 28px; font-weight: bold; line-height: 1.4; margin: 0; }
.article-signage__ttl--small { font-size: 22px; }
.article-signage__date { font-size: 12px; color: #666; padding-top: 0.5em; }
.article-signage__catimg { width: 180px; margin-bottom: 10px; float: right; margin-left: 20px; }
.article-signage__catimg > img { width: 100%; }
.article-header-sns { margin: 0 0 10px 10px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: reverse; -ms-flex-direction: row-reverse; flex-direction: row-reverse; margin: 0; padding: 0; float: right; }
.article-header-sns__item { list-style: none; display: inline-block; vertical-align: top; line-height: 0; margin-left: 10px; }
/* 著者プロフィール */
.article-author { margin: 10px 10px 20px 10px; font-size: 13px; overflow: hidden; }
.article-author__photo { float: left; width: 80px; height: 80px; display: block; overflow: hidden; padding-right: 10px; }
.article-author__photo > img { width: 100%; }
.article-author__profile { border-left: solid 0px #ddd; display: block; overflow: hidden; min-height: 80px; }
.article-author__profile-name { display: block; margin-bottom: 10px; font-size: 14px; font-weight: bold; }
.article-author__profile p { margin: 0; line-height: 1.6; }
/* 9秒でまるわかり！ */
.article-headlines-unit { width: 678px; margin: 0 auto 30px; }
.article-headlines-heading { margin: 0 0 10px 0; font-size: 16px; color: #66b6da; font-weight: bold; }
.article-headlines-heading__dropcap { font-size: 28px; font-style: italic; padding-right: 2px; }
.article-headlines { margin: 0; padding: 0; list-style: none; }
.article-headlines__item { background: url(/common/otp/images/v1/common/news-list-check.png) no-repeat left; background-size: 25px 28px; padding: 15px 0 15px 40px; border-bottom: dashed 1px #ddd; font-size: 18px; line-height: 1.4; }
/* 記事下キーワード */
.article-keywords { border-top: solid 1px #ddd; border-bottom: solid 1px #ddd; padding: 20px 0 15px 0; margin: 20px 0; overflow: hidden; }
.article-keywords::before { content: "キーワード"; line-height: 25px; font-size: 12px; color: #4d4d4d; margin-right: 1em; display: inline-block; float: left; }
/* 次ページ誘導見出し */
.article-next { margin-bottom: 30px; color: #4aa9d4; line-height: 20px; text-align: center; }
.article-next-ttl { background-color: #efefef; padding: 10px 50px; display: inline-block; text-decoration: none; font-weight: bold; color: #4aa9d4; border-radius: 6px; }
.article-next-ttl::before { content: "次ページ"; display: inline-block; margin-right: 1em; font-weight: normal; }
/* 前の記事、次の記事 */
.article-feed-page { margin-bottom: 60px; overflow: hidden; }
.article-feed-page__item { display: inline-block; background-color: #4aa9d4; color: #fff; font-size: 14px; border-radius: 2px; padding: 10px; background-repeat: no-repeat; background-size: 22px 22px; }
.article-feed-page__item-prev { float: left; background-image: url(/common/otp/images/v1/common/arrow-square-left.png); background-position: 8% center; padding-left: 70px; }
.article-feed-page__item-next { float: right; background-image: url(/common/otp/images/v1/common/arrow-square-right.png); background-position: 92% center; padding-right: 70px; }
/* -------------------------------------------------------
page-original > 記事本文用スタイル
---------------------------------------------------------- */
.article-body { width: 678px; margin: auto; margin-bottom: 40px; font-size: 1.0em; color: #333; clear: both; }
.article-body .clearfix ::after { content: ""; display: block; clear: both; }
.article-body::after { content: ""; display: block; clear: both; }
.article-body p { line-height: 1.7; text-align: justify; /* word-break : break-all; */ word-wrap: break-word; overflow-wrap: break-word; }
.article-body a { text-decoration: underline; color: #0086c2; }
.article-body a:hover { text-decoration: none; }
/* -- 見出し -- */
.article-body h3 { font-size: 24px; line-height: 1.4; color: #00448b; margin: 0 0 30px; }
.article-body h4 { font-size: 20px; line-height: 1.4; color: #00448b; margin: 0 0 25px; }
.article-body h5 { font-size: 16px; line-height: 1.4; color: #00448b; margin: 0 0 15px; }
/* -- 本文内画像 -- */
.article-body .image-area img { width: 100%; height: auto !important; }
.figure-center { margin: 15px auto; }
.figure-right { float: right; margin: 0 0 15px 15px; }
.figure-left { float: left; margin: 0 15px 15px 0; }
.caption { font-size: .8rem; color: #666; display: block; clear: both; text-align: left; }
/* -- テンプレート画像並び -- */
.images-2cols { margin: 0 auto 1.5em; clear: both; display: block; width: 660px; }
.images-2cols .image-area { float: left; margin-right: 10px; width: 320px; text-align: center; }
.images-2cols .image-area:last-child { margin-left: 10px; margin-right: 0; }
.images-2cols .image-area img { width: 100%; max-width: 320px; }
.images-3cols { margin-bottom: 1.5em; clear: both; width: 660px; }
.images-3cols .image-area { float: left; margin-right: 12px; width: 212px; text-align: center; }
.images-3cols .image-area:last-child { margin-right: 0; }
.images-3cols .image-area img { width: 100%; max-width: 212px; }
/* -- 外部リンク -- */
.article-body a.external { background: url(/common/otp/images/v1/common/link.png) no-repeat right; background-size: 15px 15px; -webkit-background-size: 15px 15px; -moz-background-size: 15px 15px; padding-right: 20px; }
/* -- リード文 -- */
.article-body .lead { border-top: solid 1px #ccc; border-bottom: solid 1px #ccc; padding: 15px 0; font-size: .9em; color: #555; }
/* -- インタビューアー -- */
.article-body .interviewer { font-size: .9em !important; color: #666; }
/* -- 写真キャプション -- */
.article-body .photo-caption { font-size: .8em !important; color: #666; display: block; clear: both; }
/* -- クレジット -- */
.article-body .credit { text-align: right; }
/* -- 囲みスタイル -- */
.article-body .box-style { background-color: #f1f1f1; padding: 15px; font-size: .9em; margin: 16px 0; }
/* -- テーブル -- */
.article-body table { border-collapse: collapse; border-spacing: 0; width: 100%; margin: 0px auto; }
.article-body table caption { text-align: left; border-top: solid 2px #00448b; border-bottom: solid 1px #00448b; color: #00448b; padding: 10px 5px; font-size: 14px; margin: 0 2px 1px; }
.article-body table th { padding: 7px; background: #00448b; color: #fff; font-weight: normal; font-size: 14px; line-height: 1.4; text-align: left; border: solid 2px #fff; }
.article-body table td { padding: 7px; border: solid 2px #fff; font-size: 14px; line-height: 1.4; }
.article-body table tr:nth-child(even) td { background: #edf2f7; }
.article-body table tr:nth-child(odd) td { background: #acc2d9; }
/* -- リスト -- */
.article-body ul { margin: 20px 60px; }
.article-body ul li { margin-bottom: 0px; line-height: 1.4; list-style: none !important; background: url(/common/otp/images/v1/common/marker.png) no-repeat 0 7px; background-size: 6px 6px; -webkit-background-size: 6px 6px; -moz-background-size: 6px 6px; padding-left: 15px; }
/* -- 動画 -- */
.article-body .video { position: relative; padding-bottom: 56.25%; padding-top: 30px; height: 0; overflow: hidden; }
.article-body .video iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
/* 記事内写真スライド */
.slide-wrapper { clear: both; position: relative; width: 100%; margin: 20px auto; }
.slide-wrapper.no-image { float: right; max-width: 100%; margin: 0px 0px 30px 30px; padding: 0px; }
.slide-wrapper.premium-login { float: left; width: 330px; margin: 20px 20px 20px auto; }
.article-photo-slide { width: 330px; float: left; }
.article-photo-slide .slide-area { position: relative; width: 100%; min-height: 290px; display: block; overflow: hidden; }
.article-photo-slide .slide-area .slide .photo { width: 330px; height: 245px; display: table-cell; vertical-align: middle; text-align: center; overflow: hidden; position: relative; background: #666; }
.article-photo-slide .slide-area .slide .photo img { max-width: 100%; max-height: 100%; margin: auto; }
.article-photo-slide .slide-area .expand { position: absolute; bottom: 5px; right: 5px; }
.article-photo-slide .slide-area .expand a { background: #666; color: #fff; text-decoration: none; display: inline-block; padding: 3px; border: solid 1px #fff; font-size: 11px; }
.article-photo-slide .slide-area .expand span { background: url(/common/otp/images/v1/common/expand-icon.png) no-repeat left; background-size: 23px 23px; -webkit-background-size: 23px 23px; -moz-background-size: 23px 23px; display: inline-block; padding-left: 30px; height: 23px; line-height: 23px; }
.article-photo-slide .prev, .article-photo-slide .next { width: 32px; height: 32px; display: block; background-size: 32px 32px; -webkit-background-size: 32px 32px; -moz-background-size: 32px 32px; background-repeat: no-repeat; white-space: nowrap; z-index: 10; position: absolute; top: 90px; cursor: pointer; }
.article-photo-slide .prev a, .article-photo-slide .next a { display: block; margin: 0px; padding: 0px; width: 100%; height: 100%; opacity: 0; }
.article-photo-slide .prev { background-image: url(/common/otp/images/v1/common/photo-arrow-prev.png); left: 0; }
.article-photo-slide .next { background-image: url(/common/otp/images/v1/common/photo-arrow-next.png); right: 50%; }
.premium-login .article-photo-slide .next { right: 0%; }
.article-photo-slide .summary p { color: #666; font-size: 12px; margin: 5px 0; }
.article-photo-slide .thumbnail { margin-top: 10px; }
.article-photo-slide .thumbnail span { width: 75px; height: 57px; overflow: hidden; display: inline-block; margin: 0 5px 10px 0; text-align: center; }
.article-photo-slide .thumbnail span a { opacity: 0.5; }
.article-photo-slide .thumbnail span a.active { opacity: 1; }
.article-photo-slide .thumbnail span:last-child { margin-right: 0; }
.article-photo-slide .thumbnail span a { height: 75px; display: block; position: relative; }
.article-photo-slide .thumbnail span img { display: block; bottom: 0; left: 0; margin: auto; max-height: 100%; max-width: 100%; position: absolute; right: 0; top: 0; }
/* gallery */
.article-body .article-gallery { margin-bottom: 50px; }
.article-body .article-gallery-main { margin: 0 auto 20px; max-width: 100%; position: relative; }
.article-body .article-gallery-main__img { display: block; margin: 0 auto; max-width: 100%; }
.article-body .article-gallery-main__caption { margin-top: 10px; font-size: .8rem; color: #666; display: block; text-align: left; }
.article-body .article-gallery-main__link { position: absolute; top: calc(50% - 20px); width: 40px; height: 40px; background-size: 40px; }
.article-body .article-gallery-main__link a { opacity: 0; width: 100%; height: 100%; }
.article-body .article-gallery-main__link--next { right: 0; background-image: url(/common/otp/images/v1/common/photo-arrow-next.png); }
.article-body .article-gallery-main__link--prev { left: 0; background-image: url(/common/otp/images/v1/common/photo-arrow-prev.png); }
.article-body .article-gallery-thumbnail { padding: 10px 0px; width: 610px; margin: 0 auto -10px; display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.article-body .article-gallery-thumbnail__item { margin-left: 10px; float: left; display: block; width: 112px; display: block; overflow: hidden; position: relative; text-align: center; height: 72px; border: 1px solid #cccccc; margin-bottom: 10px; cursor: pointer; }
.article-body .article-gallery-thumbnail__item img { bottom: 0; left: 0; margin: auto; max-height: 100%; max-width: 100%; position: absolute; right: 0; top: 0; }
.article-body .article-gallery-thumbnail__item:hover { background: rgba(0, 0, 0, 0.4); -webkit-transition: .3s; transition: .3s; opacity: 0.5; }
.article-body .article-gallery__link { display: block; clear: both; text-align: center; padding-top: 10px; }
/* login */
.article-body .article-login-bg { background: url(/common/otp/images/v1/common/bg-wave2.png) no-repeat left; background-size: 700px 280px; padding: 30px 20px; height: 280px; }
.article-body .article-login-bg__logo { margin: 54px auto 16px; display: block; width: 184px; }
.article-body .article-login-bg__logo > img { width: 100%; }
.article-body .article-login-bg__btn { display: block; padding: 10px 16px; background-color: #00448b; text-align: center; color: #fff; font-size: 15px; border-radius: 10px; border: 4px solid #fff; text-decoration: none; margin-bottom: 10px; }
.article-body .article-login-bg__btn--lightblue { background-color: #77a7e2; border: 0px; }
.article-body .article-login-bg__text { display: block; color: #00448b; font-size: 13px; line-height: 16px; margin-bottom: 20px; text-decoration: underline; }
.article-body .article-login-links { margin: 0; padding: 0; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
.article-body .article-login-links__item { padding: 0; width: 300px; list-style: none; }
.article-body .article-login-summary { margin: 10px 0px; text-align: left; color: #679ad8; font-size: 16px; line-height: 22px; font-weight: bold; }
/* -------------------------------------------------------
utility > utility
---------------------------------------------------------- */
.u-cf::after { content: " "; display: block; clear: both; }
.u-inner { width: 1058px; margin: 0 auto; }
.u-mb20 { margin-bottom: 20px; }
.u-mb30 { margin-bottom: 30px; }
.u-mb40 { margin-bottom: 40px; }
.u-mb50 { margin-bottom: 50px; }
.u-mb60 { margin-bottom: 60px; }
