@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 > トップページ用
---------------------------------------------------------- */
/* layout */
.top-main { margin-bottom: 0px; overflow: hidden; }
.top-main-block { width: 458px; float: right; }
.top-side-block { width: 245px; float: left; }
/* プレミアムコンテンツ */
.top-premium-contents { position: relative; margin-top: 60px; }
.top-premium-heading { width: 190px; height: 26px; display: block; background: url(/common/otp/images/v1/common/premium-title.png) no-repeat center; text-indent: 150%; overflow: hidden; white-space: nowrap; position: absolute; top: -15px; left: 27px; }
.top-premium-header { border-radius: 4px 4px 0 0; background: url(/common/otp/images/v1/common/premium-header-bg.png); color: #fff; text-align: center; padding: 10px 20px; }
.top-premium-header__title { font-family: Garamond, "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif; font-size: 18px; margin: 20px 0; }
.top-premium-header__title a { color: #fff; }
.top-premium-header__lead { font-size: 11px; color: #fffbb3; }
.top-premium-header__lead a { color: #fffbb3; }
.top-premium-body { border-radius: 0 0 4px 4px; background: url(/common/otp/images/v1/common/premium-body-bg.png); color: #fff; text-align: center; padding: 20px; }
.top-premium-body-item { display: block; color: #fff; margin-bottom: 20px; }
.top-premium-body-item__icon { margin-bottom: 5px; position: relative; width: 205px; display: block; overflow: hidden; padding-top: 56.25%; background-color: transparent; }
.top-premium-body-item__icon > img { position: absolute; top: 0; left: 0; bottom: 0; right: 0; margin: auto; max-height: 100%; max-width: 100%; }
.top-premium-body-item__title { font-size: 13px; line-height: 1.4; display: block; }
/* 編集部おすすめ(スライダー) */
.top-feature-unit { position: relative; }
.top-feature-unit__prev, .top-feature-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; }
.top-feature-unit__prev { background-image: url(/common/otp/images/v1/common/photo-arrow-prev.png); left: 5px; }
.top-feature-unit__next { background-image: url(/common/otp/images/v1/common/photo-arrow-next.png); right: 5px; }
.top-feature-gallery { margin: 0 auto; overflow: hidden; width: 100%; position: relative; background-color: #f1f1f1; border-left: 40px solid #f1f1f1; border-right: 40px solid #f1f1f1; padding: 30px 0; -webkit-box-sizing: content-box; box-sizing: border-box; }
.top-feature-slider { position: relative; left: 0; top: 0; margin: 0; padding: 0; }
.top-feature-item { float: left; list-style: none; margin-right: 18px; width: 180px; display: block; }
.top-feature-item:hover { text-decoration: underline; }
.top-feature-item__icon > img { margin: auto; width: 180px; height: 135px; -o-object-fit: cover; object-fit: cover; font-family: 'object-fit: cover;'; }
.top-feature-item__title { padding: 0.5em 0 0 0; display: inline-block; line-height: 1.6; color: #00448b; font-size: 13px; }
/* トップカテゴリー別ニュース */
.top-category-news { margin-bottom: 30px; }
.top-category-news-tabs { margin: 0; padding: 0; width: 100%; display: -webkit-box; display: -ms-flexbox; display: flex; }
.top-category-news-tabs__item { text-align: center; background: #4aa9d4; color: #fff; display: block; font-size: 13px; padding: 0 5px; cursor: pointer; line-height: 32px; position: relative; -webkit-box-flex: 1; -ms-flex-positive: 1; flex-grow: 1; }
.top-category-news-tabs__item.is-active, .top-category-news-tabs__item:hover { background-color: #0086c2; }
.top-category-news-tabs__item.is-active::after, .top-category-news-tabs__item:hover::after { content: ""; display: block; width: 0; height: 0; border: 8px solid transparent; border-top: solid 8px #0086c2; position: absolute; left: 50%; -webkit-transform: translate(-50%, 0); transform: translate(-50%, 0); }
.top-category-news-submenu { display: block; text-align: right; margin: 10px 0; font-size: 13px; color: #0086c2; }
.top-category-news-submenu a { color: #0086c2; display: inline-block; padding: 0 20px; border-right: solid 1px #0086c2; }
.top-category-news-submenu a:last-child { border-style: none; }
.top-category-news-list { margin-top: 30px; display: none; min-height: 150px; overflow: hidden; }
.top-category-news-list.is-active { display: block; }
.top-category-news-text { margin: 0 0 10px; padding: 0; float: left; width: 480px; }
.top-category-news-text__item { font-size: 14px; line-height: 1.5; margin-bottom: 5px; display: block; color: #333; }
.top-category-news-text__item-date { display: inline; }
.top-category-news-photo { width: 215px; height: 115px; float: right; position: relative; display: block; overflow: hidden; background-color: transparent; }
.top-category-news-photo > img { position: absolute; top: 0; left: 0; bottom: 0; right: 0; margin: auto; max-height: 100%; max-width: 100%; }
/* 人事情報 */
.top-okinawa-today { margin-bottom: 60px; }
.top-okinawa-today-tab { margin: 20px 0; position: relative; border-bottom: solid 1px #0086c2; display: -webkit-box; display: -ms-flexbox; display: flex; }
.top-okinawa-today-tab__item { -ms-flex-preferred-size: 50%; flex-basis: 50%; -webkit-box-sizing: border-box; box-sizing: border-box; text-align: center; display: inline-block; cursor: pointer; padding: 10px 0; font-size: 14px; background: #9cd0e7; color: #fff; position: relative; bottom: -1px; }
.top-okinawa-today-tab__item.is-active { display: block; color: #0086c2; background: #fff; border-top: solid 1px #0086c2; border-right: solid 1px #0086c2; border-left: solid 1px #0086c2; }
.top-okinawa-today-search { display: none; }
.top-okinawa-today-search.is-active { display: block; }
.top-okinawa-today-search__title { font-weight: normal; font-size: 18px; margin: 10px 0; }
.top-okinawa-today-search__text { font-size: 11px; color: #787878; line-height: 1.4; }
.top-okinawa-today-search input { -webkit-appearance: none; -moz-appearance: none; appearance: none; border: none; font-size: 16px; }
.top-okinawa-today-search__inputtext { background: #ececec; border: solid 1px #e7e7e7; border-radius: 2px; padding: 8px 10px; width: 280px; }
.top-okinawa-today-search__btn { background-image: url(/common/otp/images/v1/common/global-icons.png?rd=20160801); background-repeat: no-repeat; background-position: 55px -112px; background-size: 20px 240px; background-color: #00448b; color: #fff; border-radius: 4px; text-align: center; border: solid 1px #e7e7e7; padding: 8px 40px 8px 10px; line-height: 1; height: 38px; cursor: pointer; font-size: 14px; }
/* 写真ギャラリー */
.top-gallery-list { display: -webkit-box; display: -ms-flexbox; display: flex; margin-left: -20px; }
.top-gallery-item { width: 223px; margin-left: 20px; display: block; }
.top-gallery-item__icon { margin-bottom: 5px; height: 125px; position: relative; display: block; overflow: hidden; background-color: #f1f1f1; }
.top-gallery-item__icon > img { position: absolute; top: 0; left: 0; bottom: 0; right: 0; margin: auto; max-height: 100%; max-width: 100%; }
.top-gallery-item__text { font-size: 13px; color: #00448b; line-height: 1.4; }
/* blog用ブロック(http_getしたソースのスタイル。htmlが修正できないのでコーディングガイドライン未反映) */
.top-blog { margin-top: 30px; }
.top-blog ul { margin: 0; padding: 0; }
.top-blog ul::after { content: ""; display: block; clear: both; }
.top-blog ul li { list-style: none; display: table; width: 100%; border-bottom: solid 1px #ccc; padding: 8px 0; }
.top-blog ul li a { display: block; }
.top-blog ul li a:hover { text-decoration: none; }
.top-blog ul li a:hover .title { text-decoration: underline; }
.top-blog .icon-block { display: table-cell; vertical-align: top; }
.top-blog .icon { width: 60px; position: relative; display: block; }
.top-blog .icon img { margin: auto; max-height: 100%; max-width: 100%; }
.top-blog .text-block { display: table-cell; vertical-align: top; padding-left: 10px; line-height: 1.4; color: #00448b; font-size: 13px; width: 100%; }
.top-blog .text-block .text { color: #aaa; font-size: 16px; display: block; }
.top-blog .title { display: block; margin-bottom: 10px; color: #00448b; font-size: 14px; }
.top-blog .summary { display: block; color: #666; font-size: 12px; }
.top-blog ul + span { display: block; margin-top: 10px; font-size: 13px; text-align: center; }
.top-blog ul + span a, .top-blog ul + span a:hover, .top-blog ul + span a:visited { color: #00448b; }
/* -------------------------------------------------------
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; }
