@charset "UTF-8"; /* -------------------------------------------------------------------- Base reset css -------------------------------------------------------------------- */ article, aside, details, figcaption, figure, footer, header, hgroup, hr, menu, nav, section { display: block; } a, hr { padding: 0; } abbr, address, article, aside, audio, b, blockquote, body, canvas, caption, cite, code, dd, del, details, dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, p, pre, q, samp, section, small, span, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, ul, var, video { margin: 0; padding: 0; border: 0; outline: 0; font-weight: inherit; font-style: inherit; font-size: 100%; font-family: inherit; vertical-align: baseline; background: 0 0; } caption, table td, table th { text-align: left; font-weight: 400; } ins, mark { background-color: #ff9; color: #000; } img { vertical-align: bottom; } :focus { outline: 0; } body { line-height: 1; } table { border-collapse: collapse; border-spacing: 0; empty-cells: show; } table td, table th { vertical-align: top; } ol, ul { list-style: none; } blockquote, q { quotes: none; } blockquote:after, blockquote:before, q:after, q:before { content: ''; content: none; } a { margin: 0; font-size: 100%; vertical-align: baseline; background: 0 0; } a img, iframe { border: none; } ins { text-decoration: none; } mark { font-style: italic; font-weight: 700; } del { text-decoration: line-through; } abbr[title], dfn[title] { border-bottom: 1px dotted; cursor: help; } hr { height: 1px; border: 0; border-top: 1px solid rgba(0, 0, 0, 0.1); margin: 2rem 0; } input, select { vertical-align: middle; } select { font-size: 100%; font-family: Arial, sans-serif; margin: inherit; } button, input, textarea { font-size: 100%; font-family: inherit; } ol { margin-left: 2em; } br { letter-spacing: 0; } @media screen and (max-width:480px) { hr { margin: 1rem 0; } } /* -------------------------------------------------------------------- Base css -------------------------------------------------------------------- */ @font-face { font-family: 'FuturaMedium'; src: url('../webfonts/FuturaMedium.woff2') format('woff2'), url('../webfonts/FuturaMedium.woff') format('woff'); } body, ol, ul, dl, li, dt, dd, table, th, td, input, textarea, select, h1, h2, h3, h4, h5, h6 { color: #333; font-family: "Times New Roman", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, serif; font-weight: 300; letter-spacing: 0; margin: 0; padding: 0; -webkit-text-size-adjust: 100%; } html { font-size: 100%; } body { min-width: 320px; line-height: 1.5; font-size: 126%; word-break: break-all; position: relative; overflow-x: hidden; background-color: #f5f5f5; } .futura-txt { font-family: 'FuturaMedium', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'Yu Mincho Light', 'YuMincho', 'Yu Mincho', '游明朝体', sans-serif !important; } @media screen and (max-width: 1366px) { body { font-size: 120%; } } @media screen and (max-width: 480px) { body { font-size: 100%; } } img { width: auto; max-width: 100%; height: auto; vertical-align: middle; border-radius: 0.5rem; overflow: hidden; } input { padding: 5px 8px; } textarea { padding: 3px; } ul { list-style: none; } ol { margin: 0px 0px 0px 21px; } ol>li { list-style: decimal outside; margin: 0px 0px 3%; } a { color: #1d1d1f; text-decoration: underline; outline: 0; } a:hover, a:active { color: #1d1d1f; text-decoration: none; } a:hover { opacity: 0.7; } @media screen and (min-width: 1001px) { a[href^="tel"] { pointer-events: none; } } em { font-style: normal; font-weight: bold; } strong { font-style: normal; font-weight: bold; } .txt-mincho { font-family: "Times New Roman", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, serif; } .txt-hightlight { color: #0066cc !important; } .txt-large { font-size: 150% !important; } .txt-big { font-size: 120% !important; } figure { text-align: center; } /* -------------------------------------------------------------------- block common style -------------------------------------------------------------------- */ .comm-blc { margin-left: auto; margin-right: auto; padding: 0 4%; box-sizing: border-box; } .padding-comm { padding-top: 6rem; padding-bottom: 6rem; box-sizing: border-box; } /* -------------------------------------------------------------------- title style -------------------------------------------------------------------- */ .ttl-style01 { font-size: 200%; font-weight: bold; text-align: center; margin-bottom: 3rem; display: block; width: 100%; box-sizing: border-box; } .ttl-style02 { font-size: 130%; font-weight: bold; padding-bottom: 1rem; display: block; width: 100%; text-align: left; box-sizing: border-box; } /* aside secon-ttl ---------------- */ .secon-ttl { font-size: 120%; font-weight: bold; padding-bottom: 10px; margin-bottom: 10px; display: block; border-bottom: 2px solid #333; box-sizing: border-box; } @media screen and (max-width:1366px) { .ttl-style01 { font-size: 180%; } } @media screen and (max-width:1200px) { .ttl-style02 { font-size: 120%; } .secon-ttl { font-size: 100%; } } @media screen and (max-width:1000px) { .secon-ttl { font-size: 126%; } } @media screen and (max-width:480px) { .ttl-style02 { padding-bottom: 1rem; } .ttl-style01 { font-size: 160%; margin-bottom: 1.5rem; } } /* -------------------------------------------------------------------- button style -------------------------------------------------------------------- */ .btn-blc { text-align: center; display: block; width: 100%; padding-top: 2rem; box-sizing: border-box; } .btn-blc .btn { display: inline-block; text-decoration: none; background-color: #0066cc; color: #fff; max-width: 300px; width: 100%; padding: 15px 20px; line-height: 1.5; text-align: center; border-radius: 5px; box-shadow: 0 4px 9px -4px #3b71ca; box-sizing: border-box; } /* -------------------------------------------------------------------- header -------------------------------------------------------------------- */ #header { display: block; width: 100%; box-shadow: 0 4px 15px -3px rgba(0, 0, 0, 0.07), 0 4px 20px -2px rgba(0, 0, 0, 0.04); position: relative; z-index: 1; background-color: #fff; } #header .inner { width: 100%; display: flex; } /* logo-blc --------------------------- */ #header .logo-blc { width: 70%; display: flex; align-items: center; padding: 10px 20px; box-sizing: border-box; } #header .logo-blc .txt-catch { order: 2; display: block; font-size: 90%; width: calc(100% - 400px); box-sizing: border-box; } #header .logo-blc .txt-catch>p { font-size: 126%; font-weight: 500; } #header .logo-blc .txt-catch+.logo { padding-right: 20px; } #header .logo-blc .logo { order: 1; max-width: 400px; } /* link-blc --------------------------- */ #header .link-blc { width: 30%; } #header .link-blc ul { display: flex; height: 100%; box-sizing: border-box; } #header .link-blc ul li { width: calc(100% / 2); } #header .link-blc ul li a { text-decoration: none; background-color: #0066cc; text-align: center; padding: 30px 20px; color: #fff; height: 100%; display: flex; justify-content: center; align-items: center; box-sizing: border-box; } #header .link-blc ul li:last-child a { background-color: #003b84; } @media screen and (max-width:1660px) { #header .logo-blc { width: 65%; } #header .link-blc { width: 35%; } #header .logo-blc .logo { max-width: 35%; } #header .logo-blc .txt-catch { width: 65%; font-size: 1.1vw; } } @media screen and (max-width:1366px) { #header .link-blc ul li a { font-size: 90%; } } @media screen and (max-width:1200px) { #header .link-blc ul li a { font-size: 1.5vw; } } @media screen and (max-width:1000px) { #header .logo-blc { width: 100%; } #header .inner { flex-wrap: wrap; } #header .link-blc { width: 100%; } #header .link-blc ul li a { padding: 10px 10px; font-size: 100%; } #header .logo-blc .txt-catch { font-size: 80%; width: 100%; } } @media screen and (max-width:767px) { #header .logo-blc .txt-catch { font-size: 2vw; } } @media screen and (max-width:640px) { #header .logo-blc { flex-wrap: wrap; justify-content: center; padding: 10px 4%; } #header .logo-blc .txt-catch { text-align: center; font-size: 2.3vw; } #header .logo-blc .logo { max-width: 100%; width: 100%; } #header .logo-blc .txt-catch+.logo { margin-bottom: 10px; padding-right: 0; } } @media screen and (max-width:480px) { #header .link-blc ul li a { font-size: 80%; } #header .logo-blc .txt-catch { font-size: 70%; } } /* -------------------------------------------------------------------- main-visual -------------------------------------------------------------------- */ #main-visual { display: flex; position: relative; box-shadow: 0 4px 15px -3px rgba(0, 0, 0, 0.07), 0 4px 20px -2px rgba(0, 0, 0, 0.04); } #main-visual .txt-blc { width: 50%; padding: 2rem; display: flex; flex-wrap: wrap; align-items: center; align-content: center; justify-content: center; box-sizing: border-box; background-color: #fff; } #main-visual .img-blc { background-size: cover; background-position: center; background-repeat: no-repeat; width: 50%; min-height: 400px; } #main-visual .txt-blc figure { width: 100%; text-align: center; } #main-visual .txt-blc figure img { border-radius: 0; } #main-visual .txt-blc .txt { font-size: 150%; text-align: center; display: block; width: 100%; font-weight: bold; } #main-visual .txt-blc .txt .txt-big { font-size: 140% !important; } #main-visual .txt-blc figure+.txt { margin-top: 1rem; } @media screen and (max-width:1366px) { #main-visual .txt-blc .txt { font-size: 126%; } } @media screen and (max-width:1000px) { #main-visual { flex-wrap: wrap; } #main-visual .txt-blc { width: 100%; } #main-visual .img-blc { width: 100%; min-height: 0; position: static; padding-top: 40%; } } @media screen and (max-width:767px) { #main-visual .txt-blc figure+.txt { margin-top: 10px; } } @media screen and (max-width:640px) { #main-visual .txt-blc { padding: 1rem 4%; } } @media screen and (max-width:480px) { #main-visual .img-blc { padding-top: 50%; } } /* -------------------------------------------------------------------- contents -------------------------------------------------------------------- */ #contents { display: flex; justify-content: space-between; margin: 0 auto; padding: 2rem 2rem 6rem 2rem; max-width: 1920px; box-sizing: border-box; } #primary-blc { width: 70%; box-sizing: border-box; } #primary-blc article { margin-top: 2rem; padding: 4rem 4%; box-shadow: 0 2px 15px -3px rgba(0, 0, 0, 0.07), 0 10px 20px -2px rgba(0, 0, 0, 0.04); box-sizing: border-box; border-radius: 0.5rem; background-color: #fff; } #primary-blc article:first-child { margin-top: 0; } #secondary-blc { width: calc(30% - 2rem); } #secondary-blc .list-left-blc { margin-bottom: 2rem; padding: 40px 20px; box-shadow: 0 2px 15px -3px rgba(0, 0, 0, 0.07), 0 10px 20px -2px rgba(0, 0, 0, 0.04); box-sizing: border-box; border-radius: 0.5rem; background-color: #fff; } #secondary-blc .list-left-blc:last-child { margin-bottom: 0; } @media screen and (max-width:1200px) { #secondary-blc .list-left-blc { padding: 20px 10px; } } @media screen and (max-width:1000px) { #contents { padding: 2rem 4%; flex-wrap: wrap; } #secondary-blc { width: 100%; } #primary-blc { width: 100%; } #secondary-blc+#primary-blc { margin-top: 2rem; } } @media screen and (max-width:480px) { #primary-blc article { padding: 3rem 4%; } } /* g-nav ---------------------------- */ .g-nav>ul li a { display: block; text-decoration: none; padding: 15px 50px 15px 15px; border-bottom: 1px solid rgba(0, 0, 0, 0.1); position: relative; box-sizing: border-box; } .g-nav>ul li a::after { content: ""; background: url(../img/common/arrow_right.png) no-repeat; background-size: 7px auto; background-position: center; background-color: #06c; width: 20px; height: 20px; color: #fff; border-radius: 999px; position: absolute; right: 20px; top: 20px; } @media screen and (max-width:1200px) { .g-nav>ul li a { padding: 10px 40px 10px 10px; } .g-nav>ul li a::after { top: 15px; right: 7px; } } @media screen and (max-width:1000px) { .g-nav>ul li a { padding: 10px 35px 10px 10px; font-size: 90%; } .g-nav>ul li a::after { right: 7px; top: 13px; } } @media screen and (max-width:640px) { .g-nav>ul li a::after { top: 2.3vw; } } @media screen and (max-width:480px) { .g-nav>ul li a::after { top: 11px; } } /* -------------------------------------------------------------------- section-content -------------------------------------------------------------------- */ .section-content { margin-bottom: 4rem; } .section-content:last-child { margin-bottom: 0; } .section-content .txt-blc+.img-blc { padding-top: 2rem; } .section-content .img-blc { width: 100%; display: block; box-sizing: border-box; } .section-content .txt-blc p { display: block; width: 100%; } .section-content .txt-blc .txt-list { margin-top: 30px; } .section-content .txt-blc .txt-list:nth-of-type(1) { margin-top: 0; } /* img-right / img-left --------------------------- */ .section-content.img-right .inner, .section-content.img-left .inner { display: flex; flex-wrap: wrap; } .section-content.img-right .inner .ttl-style02, .section-content.img-left .inner .ttl-style02 { text-align: left; } .section-content.img-right .txt-blc, .section-content.img-right .img-blc, .section-content.img-left .txt-blc, .section-content.img-left .img-blc { width: 50%; box-sizing: border-box; } .section-content.img-right .img-blc { order: 2; } .section-content.img-right .txt-blc { order: 1; } .section-content.img-left .img-blc { order: 1; } .section-content.img-left .txt-blc { order: 2; } .section-content.img-right .txt-blc, .section-content.img-left .txt-blc { display: flex; flex-wrap: wrap; align-items: center; align-content: center; box-sizing: border-box; } .section-content.img-right .txt-blc .word-blc, .section-content.img-left .txt-blc .word-blc { text-align: left; } .section-content.img-right .img-blc, .section-content.img-left .img-blc { padding-top: 0; } .section-content.img-right .txt-blc+.img-blc { padding-left: 2rem; } .section-content.img-left .txt-blc+.img-blc { padding-right: 2rem; } .section-content.img-right .img-blc, .section-content.img-left .txt-blc { margin-left: auto; } .section-content.img-right .btn-blc, .section-content.img-left .btn-blc { text-align: left; } /* img-top / img-btm --------------------------- */ .section-content.img-top .inner, .section-content.img-btm .inner { display: flex; flex-wrap: wrap; } .section-content.img-top .txt-blc .ttl-style02, .section-content.img-btm .txt-blc .ttl-style02 { text-align: center; } .section-content.img-top .txt-blc, .section-content.img-top .img-blc, .section-content.img-btm .txt-blc, .section-content.img-btm .img-blc { width: 100%; } .section-content.img-top .img-blc { order: 1; padding-top: 0 !important; } .section-content.img-top .txt-blc { order: 2; } .section-content.img-btm .img-blc { order: 2; } .section-content.img-btm .txt-blc { order: 1; } .section-content.img-top .txt-blc .word-blc, .section-content.img-btm .txt-blc .word-blc { text-align: center; display: block; } .section-content.img-top .txt-blc+.img-blc { padding-bottom: 2rem; box-sizing: border-box; } .section-content.img-btm .txt-blc+.img-blc { padding-top: 2rem; box-sizing: border-box; } @media screen and (max-width:767px) { .section-content.img-right .txt-blc, .section-content.img-left .txt-blc { width: 100%; padding: 0; } .section-content.img-right .img-blc, .section-content.img-left .img-blc { width: 100%; } .section-content.img-right .txt-blc+.img-blc { padding-top: 2rem; padding-left: 0; } .section-content.img-left .txt-blc+.img-blc { padding-bottom: 2rem; padding-right: 0; } } @media screen and (max-width:480px) { .section-content { margin-bottom: 2rem; } .section-content.img-right .txt-blc+.img-blc { padding-top: 1rem; } .section-content.img-left .txt-blc+.img-blc { padding-top: 0; } .section-content .txt-blc .txt-list { margin-top: 20px; } .section-content .txt-blc+.img-blc { padding-top: 1rem; } } /* -------------------------------------------------------------------- list-style01 -------------------------------------------------------------------- */ .list-style01 { display: block; padding-left: 20px; box-sizing: border-box; } .list-style01 li { padding-left: 20px; position: relative; margin-top: 10px; } .list-style01 li::before { content: ""; position: absolute; top: 10px; left: 0px; display: block; width: 10px; height: 10px; border-radius: 5px; background: #0066cc; } .list-style01 li:first-child { margin-top: 0; } .list-style01 li>a { text-decoration: none; display: inline-block; } @media screen and (max-width:480px) { .list-style01 { padding-left: 10px; } .list-style01 li::before { top: 6px; } } /* -------------------------------------------------------------------- breadcrumbs -------------------------------------------------------------------- */ @media screen and (min-width:1001px) { #breadcrumbs ul li a:hover { text-decoration: underline; } } #breadcrumbs { width: 100%; display: block; background-color: #fff; box-shadow: 4px 0 15px -3px rgba(0, 0, 0, 0.07), 4px 0 20px -2px rgba(0, 0, 0, 0.04); } #breadcrumbs ul { display: flex; flex-wrap: wrap; max-width: 1200px; margin-left: auto; margin-right: auto; padding: 10px 4%; box-sizing: border-box; } #breadcrumbs ul li { padding-right: 15px; margin-right: 10px; position: relative; } #breadcrumbs ul li::after { content: "/"; position: absolute; right: 0; top: 0; } #breadcrumbs ul li:last-child { padding-right: 0; margin-right: 0; } #breadcrumbs ul li:last-child::after { content: none; } #breadcrumbs ul li a { text-decoration: none; color: #0066cc; font-size: 90%; } #breadcrumbs ul li.current a { color: #bbb; pointer-events: none; } #footer { background-color: #eaf8fe; box-sizing: border-box; padding: 4rem 0 0; } #footer .f-logo img { border-radius: 0; } #footer #f-nav { margin-top: 2rem; } #footer #f-nav ul { display: flex; flex-wrap: wrap; justify-content: center; } #footer #f-nav ul li a { text-decoration: none; margin-right: 20px; display: inline-block; text-align: center; box-sizing: border-box; line-height: 2.5; } #footer #f-nav ul li:last-child a { margin-right: 0; } #footer #copyright { margin-top: 2rem; text-align: center; font-size: 70%; display: block; padding-bottom: 20px; box-sizing: border-box; } @media screen and (max-width:640px) { #footer #f-nav ul li a { font-size: 90%; } } @media screen and (max-width:480px) { #footer { padding: 2rem 0 0; } #footer #f-nav { margin-top: 1rem; } #footer #f-nav ul li a { font-size: 80%; margin-right: 10px; } #footer #copyright { margin-top: 1rem; } } /* -------------------------------------------------------------------- other -------------------------------------------------------------------- */ @media screen and (min-width:641px) { .br-sp640 { display: none; } } @media screen and (min-width:481px) { .br-sp480 { display: none; } }