@charset "utf-8";

html { font-size: 62.5% }
/*header, nav, main, article, div, section, aside, dl, footer { display: block; overflow: hidden }*/
header, nav, main, article, section, aside, dl, footer { display: block; overflow: hidden }
p { margin: 0 }
a { color: #fff }
a:hover { color: rgba(255, 255, 255, .8) }
ul, ol, dl, dt, dd { margin: 0; padding: 0 }
img { border: none; vertical-align: middle }
#wrapper img { height: auto }
mark { background: linear-gradient(transparent 64%, #ffdfef 64%); color: #000; font-weight: 700; padding: 0 1px 1px; font-style: normal }
form { margin-top: 24px }
label { display: block }
input[type='text'], input[type='password'], input[type='date'], textarea, select { padding: 5px; border: 2px solid #ddd; border-radius: 4px; transition: .2s; outline: none }
input[type='text']:focus, input[type='password']:focus, input[type='date']:focus, textarea:focus, select:focus { border-color: #1b95e0 }
input[type='submit'], input[type='reset'], input[type='button'], button { transition: .2s; background-color: #fff; color: #333; text-decoration: none; padding: 16px; line-height: 1; font-size: 93.75%; cursor: pointer; border: 1px solid #bbb; border-radius: 4px; font-family: 'Noto Sans JP', sans-serif }
input[type='submit']:hover, input[type='reset']:hover, input[type='button']:hover, button:hover { background-color: #fefefe; border-color: #aaa }
form dl { background-color: rgba(250, 249, 244, .16); margin-bottom: 16px; border: 1px solid rgb(239, 237, 222); border-radius: 8px; padding: 16px }
form dt { font-weight: 700 }
form dt::before { font-family: 'Font Awesome 5 Free'; content: '\f0da\00a0' }
form dt strong { color: #fff; font-weight: 400; font-size: 1.1rem; line-height: 1; padding: 2px 4px; border-radius: 2px; border: none; background-color: rgba(0, 195, 52, 1); display: inline-block }
form dd { margin-top: 12px }
form dd span { display: block }
form dd span:not(:first-child) { margin-top: 8px }
textarea { width: calc(100% - 14px) }
hr { height: 6px; background-color: rgba(255, 255, 255, .4); border: none; margin: 0 }
.flexwrap { flex-wrap: wrap }
.flexspacebetween { justify-content: space-between }
.flexspacearound { justify-content: space-around }
.flexcenter { justify-content: center }
.myframe01 { border: 5px solid rgb(61, 145, 255); padding: 16px 24px; background-color: rgba(255, 255, 255, .16) }
.myframe02 { padding: 16px 24px; background-color: rgba(250, 249, 244, .16); border-radius: 8px; border: 1px solid #fff }
.myframe03 { border: 3px solid rgba(61, 145, 255, .88); border-radius: 4px }
.myframe03 dt { background-color: rgba(61, 145, 255, .88); color: #fff; padding: 0 24px 3px }
.myframe03 dd { padding: 16px 24px }
.myframe04 { padding: 8px; background-size: 8px 8px; background-color: rgba(61, 145, 255, .4); background-image: linear-gradient(45deg, rgba(61, 145, 255, .72) 24%, transparent 24%, transparent 48%, rgba(61, 145, 255, .72) 48%, rgba(61, 145, 255, .72) 72%, transparent 72%, transparent); opacity: .88 }
.myframe04inner { background: #fff; padding: 16px 24px; color: #012036 }
.myframe05 { padding: 8px 24px 16px; border-radius: 8px; border: 4px solid rgba(61, 145, 255, .88); background-color: #fff; color: #012036 }
.myframe05 legend { font-weight: 500; color: #fff; padding: 2px 8px; background-color: rgb(61, 145, 255); border-radius: 4px; border: none }
.mycard { background-color: #fff }
.mycardimg { border: none; border-top-left-radius: 8px; border-top-right-radius: 8px }
.mycard dl { border-right: 1px solid #fff; border-bottom: 1px solid #fff; border-left: 1px solid #fff; border-bottom-left-radius: 8px; border-bottom-right-radius: 8px; text-align: center }
.mycard dt { font-weight: 500 }
.mycard dd a { font-size: 80% }
.mycard2 dl { padding: 24px }
.mycard2 dt { font-size: 116% }
.mycard3 dl { padding: 16px }
.mycard3 dt { font-size: 108% }
.mycard4 dl { padding: 16px }
.mycard4 dt { font-size: 100% }
.myfadebanner { position: relative; cursor: pointer }
.myfadebanner img { max-width: 100% }
.myfadebanner div { position: absolute; bottom: 0; left: 0; right: 0; background-color: rgba(206, 237, 74, 0.88); color: #012063; text-align: center; padding: 1.6%; font-weight: 500; transition: .3s }
.myfadebanner:hover div { padding-top: 3.2%; padding-bottom: 3.2% }
.myrelativebox { position: relative; padding-bottom: 48px }
.myrelativebtn { position: absolute; bottom: 0; right: 0; left: 0; text-align: center }
.mybtn01 a { display: inline-block; line-height: 1; color: #fff; text-decoration: none; background-color: rgba(61, 145, 255, 1); padding: 6px 8px; border: none; border-radius: 4px; font-size: 88%; transition: .3s; white-space: nowrap }
.mybtn01 a:hover { background-color: rgba(61, 145, 255, .72) }
.mybtn01 a::before { font-family: 'Font Awesome 5 Free'; content: '\f0da\00a0'; font-weight: 900 }
/*.mybtn04 { transition: .3s }
.mybtn04:hover { opacity: .72 }*/
.mybtnblock a { display: block !important; text-align: center }
.myboxautoth th { width: auto }
.ultable { display: table; padding: 0 }
.ultable li { display: table-row }
.ultable li span { display: table-cell; padding-right: 16px }
.ultable li span:first-child { font-weight: 700; color: #000 }
.tal { text-align: left }
.tac { text-align: center }
.tar { text-align: right }
.myiframe { position: relative; padding-top: 56.25% }
.myiframe iframe { position: absolute; top: 0; left: 0; right: 0; width: 100%; height: 100%; border: none }
.mytoggledl dt { cursor: pointer }
.mytoggledl dd { display: none }
.wcedit_40020A814601 .mytoggledl dd { display: block }
.navpagelink { display: flex; justify-content: space-between }
.navpagelink div { flex-grow: 1; text-align: center; font-size: 87.5% }
.navpagelink div:not(:first-child) { margin-left: 3px }
.navpagelink a { display: block; background-color: rgb(61, 145, 255); text-decoration: none; color: #666; padding: 8px 0; transition: .3s }
.navpagelink a:hover { opacity: .72 }
.pagelinkon { position: relative; padding-bottom: 8px }
.pagelinkon strong { display: block; background-color: rgb(61, 145, 255); color: #fff; padding: 8px 0; font-weight: 400 }
.pagelinkon::after { content: ''; width: 0; height: 0; border-top: 8px solid rgb(61, 145, 255); border-right: 8px solid transparent; border-bottom: 0 solid transparent; border-left: 8px solid transparent; position: absolute; right: 0; bottom: 0; left: 0; margin: 0 auto }
.mylist05 { list-style: none }
.mylist05 li { padding-left: 1em; text-indent: -1em; font-size: 87.5% }
.mylist05 li::before { content: '※' }
.mylist05 li ~ li { margin-top: .6rem }
.fsmallx { font-size: 75% }
.fsmall { font-size: 87.5% }
.fmedium { font-size: 100% }
.flarge { font-size: 112.5% }
.flargex { font-size: 125% }
.flargexx { font-size: 150% }
.flargexxx { font-size: 175% }
.flargexxxx { font-size: 200% }
.w32p { width: 32% }
.w48p { width: 48% }
.w64p { width: 64% }
.w80p { width: 80% }
#lightbox { background-color: #fff; padding: 16px 16px 32px; border-radius: 4px; max-width: calc(100% - 32px) }
#lightboxCaption { color: #333; font-size: 1.3rem; text-align: center; padding: 10px 16px 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; width: calc(100% - 32px) !important }
#lightboxIndicator { border: 1px solid #fff }
#lightboxOverallView, #overlay { background-color: #000; opacity: .8 }
.mycontacttitle, .mycontactphone, .mycontacttext, .mycontactor, .mycontactbtn { display: block; overflow: hidden }

@media (max-width: 375px) {
.w32p, .w48p { width: 64% }
.w80p { width: calc(100% - 14px) }
}

@media (max-width: 767px) {
body { margin: 0; background-color: #094397; color: #fff; line-height: 1.732; font-size: 1.4rem; font-family: 'Noto Sans JP', sans-serif; font-feature-settings: 'palt' }
h1, #headerr, #globalnav, .largebr { display: none }
#wrapper { position: relative; overflow: hidden; }
#containerheader { background-color: #012063; padding: 16px; overflow: hidden; }
header { }
#headerl { float: left; clear: both; width: 72%; max-width: 393px }
#headerlogo { }
#headerlogo img { max-width: 100% }
#hamicon { float: right }
#hamicon i { display: block; cursor: pointer; color: #fff; font-size: 2.8rem }
#mainvisual { }
#mainvisual img { max-width: 100% }
#containerpagetitle { position: relative; height: 172px }
#pagetitleimg { width: 1032px; height: 172px; position: absolute; top: 0; left: 50%; margin-left: -516px; overflow: hidden; }
#pagetitleimg img { max-width: 100% }
#pagetitlemask { width: 1032px; height: 172px; position: absolute; top: 0; left: 50%; margin-left: -516px }
#pagetitlemask img { max-width: 100% }
#pagetitle { text-align: center; position: absolute; top: 40px; right: 0; left: 0; color: #fff; text-shadow: 1px 1px 1px #000 }
#pagetitlej { font-size: 3rem; font-weight: 500 }
#pagetitlee { font-family: 'Fira Sans Extra Condensed', sans-serif; font-size: 1.8rem; letter-spacing: 2px; font-weight: 400 }
#containermysec00outer { }
#containermysec00 { }
#mysec00side { background-color: #fff; padding: 16px }
#mysec00side h2 { font-family: 'Fira Sans Extra Condensed', sans-serif; color: #012063; font-size: 3.2rem; text-align: center; padding-bottom: 16px; font-weight: 500 }
#mysec00banners01 { display: flex; justify-content: space-between; text-align: center }
#mysec00banners02 { display: flex; justify-content: space-between; margin-top: 16px; text-align: center }
.mysec00fadebanner { width: 33.3333% }
.mysec00fadebanner .myfadebanner div { font-weight: 700; font-size: 1.6rem }
.mysec00banner { font-size: 0; width: 25% }
.mysec00banner img { max-width: 100% }
#mysec00main { margin: 24px 16px 40px }
#mysec01 { }
#mysec01 h2 { font-family: 'Fira Sans Extra Condensed', sans-serif; color: #ceec4a; font-size: 3.2rem; font-weight: 400; margin-bottom: 24px; text-align: center }
.mysec01info { margin-bottom: 8px; padding-bottom: 8px; border-bottom: 1px solid rgba(255, 255, 255, .32) }
.mysec01info dt { font-size: 1.2rem; opacity: .64 }
.mysec01info dd { }
#mysec01btn { padding-top: 8px; text-align: center }
.mybtn05 a { display: inline-block; font-family: 'Fira Sans Extra Condensed', sans-serif; color: #ceec4a; font-size: 1.6rem; font-weight: 400; letter-spacing: 1px; text-decoration: none; border-bottom: 2px solid #fff }
.mybtn05 a:hover { opacity: .72 }
#mysec02 { margin-top: 56px }
#mysec02 h2 { font-family: 'Fira Sans Extra Condensed', sans-serif; color: #ceec4a; font-size: 3.2rem; font-weight: 400; margin-bottom: 24px; text-align: center }
#mysec02 p { margin-bottom: 24px }
#mysec02 p br { display: none }
.mysec02box { position: relative; margin-bottom: 24px }
.mysec02img { margin: 0 auto }
.mysec02img img { width: 100%; max-width: 555px }
.mysec02mobmask { position: absolute; top: 0; right: 0; bottom: 0; left: 0 }
.mysec02mobmask img { width: 100%; max-width: 555px }
.mysec02mask { position: absolute; top: 6%; right: 0 }
.mysec02mask img { width: 88%; max-width: 555px; float: right }
#containerfooterouter { padding-bottom: 56px; overflow: hidden;}
#containerfooter { overflow: hidden; }
footer { margin: 0 16px }
#footerh2 { }
#footerh2 h2 { font-family: 'Fira Sans Extra Condensed', sans-serif; color: #ceec4a; font-size: 3.2rem; 2px; font-weight: 400; margin-bottom: 24px; text-align: center }
#footerh2line { display: none }
#footerimg { text-align: center }
#footerimg img { max-width: 100% }
#footerinfo { margin-top: 16px; text-align: center }
.footerinfo { margin-bottom: 8px }
.footerinfo table { margin: 0 auto }
#footerinfobtn { text-align: center; margin-top: 24px }
#navfooter { background-color: #fff; padding: 16px 8px 8px; overflow: hidden; }
#navfooter ul { display: flex; flex-wrap: wrap }
#navfooter li { display: block; margin: 0 8px 8px; width: calc(50% - 18px); text-align: center; border: 1px solid rgba(255, 255, 255, .4) }
#navfooter a { color: #012036; text-decoration: none; line-height: 1.1 }
#footercopy { background-color: #101d27; text-align: center; color: #fff; font-size: 1.2rem; padding: 8px 0; overflow: hidden; }
#container { margin-top: 16px; overflow: hidden;}
#maincontents { }
#drawernav { background-color: #001950; color: #fff }
#drawernavinfo { padding: 16px 16px 0; font-size: 1.3rem }
#drawernavcontact { padding: 16px 16px 0; line-height: 1 }
#drawernavcontact div { margin-bottom: 16px }
#drawernavcontact a { border-radius: 4px; padding: 8px; color: #001950; display: block; background-color: #ceec4a; text-decoration: none }
#drawernavcontact .myphone::before { display: inline-block; font-family: 'Font Awesome 5 Free'; content: '\f098'; width: 1.28571429em; text-align: center; font-weight: 900; font-size: 107.1429% }
#drawernavcontact .myshop::before { display: inline-block; font-family: 'Font Awesome 5 Free'; content: '\f07a'; width: 1.28571429em; text-align: center; font-weight: 900; font-size: 107.1429% }
#drawernavcontact .myschool::before { display: inline-block; font-family: 'Font Awesome 5 Free'; content: '\f549'; width: 1.28571429em; text-align: center; font-weight: 900; font-size: 107.1429% }
#drawernav ul { padding: 0; list-style: none }
#drawernav li { display: block; border-bottom: 1px solid rgba(255, 255, 255, .24) }
#drawernav li a { color: #fff; text-decoration: none; display: block; padding: 8px 16px }
#drawernav li a::before { display: inline-block; font-size: 78.5714%; font-family: 'Font Awesome 5 Free'; content: '\f054'; width: 1.28571429em; text-align: center; font-weight: 900 }
#drawernav aside { text-align: right; margin: 12px 16px 12px 0 }
#drawernav aside a { font-size: 85.714%; color: #bbb; text-decoration: none; display: inline-block; border: 1px solid #888; padding: 0 4px; border-radius: 4px }
#topicpath { margin: 0 16px 32px; font-size: 92.857% }
#topicpath a { color: #fff; text-decoration: underline }
.sec1032 { margin: 0 16px }
.secflex { margin: 0 8px; display: flex }
.arrowh { text-align: center; font-size: 285.714%; line-height: 1 }
.div12 { margin: 0 8px 24px }
.div12flex { display: flex; flex-wrap: wrap; justify-content: space-between }
.div12flex11 { width: 100%; max-width: 492px; margin: 0 0 16px }
.div12flex12 { width: calc(50% - 8px); max-width: 234px; margin: 0 0 16px }
.div12border, .div13border { margin: 0 8px 24px; border: 3px solid rgba(61, 145, 255, .88) }
.divborderinner { padding: 16px }
.div12 dd { padding: 8px 0 0 }
.div12l { width: 42%; padding-left: 8px }
.div12r { width: 42%; padding-right: 8px }
.div12l dd, .div12r dd { padding: 8px 0 0 }
.div13 { margin: 0 8px 24px }
.div13 dd { padding: 8px 0 0 }
.div14 { margin: 0 8px 24px }
.div14 dd { padding: 8px 0 0 }
.dl01, .dl02 { margin-bottom: 8px; padding-bottom: 8px; border-bottom: 1px solid rgba(255, 255, 255, .4); display: block }
.dl01 dt, .dl02 dt { font-weight: bold; font-size: 92.857%; padding-right: 8px; width: calc(28% - 8px); float: left; clear: both }
.dl01 dd, .dl02 dd { padding-left: 8px; float: right; width: calc(72% - 12px); border-left: 4px solid rgba(255, 255, 255, .4) }
.mylist01, .mylist02 { margin-top: 16px }
.mylist03 { padding-left: 24px }
.mylist03 li { margin-bottom: 4px }
.mylist04 { list-style: none; padding-left: 4px }
.mylist04 li { padding: 6px 0 0 26px; position: relative; margin-bottom: 4px }
.mylist04 li::before { position: absolute; font-family: 'Font Awesome 5 Free'; left: 0; top: 0; content: '\f0a4'; color: rgb(61, 145, 255); font-size: 157.143% }
.mybox01 { width: 100%; border-collapse: collapse }
.mybox01 th { width: 32%; padding: 8px; border-top: 1px solid rgba(255, 255, 255, .4); border-bottom: 1px solid rgba(255, 255, 255, .4); text-align: left; font-size: 92.857% }
.mybox01 td { padding: 8px; border-top: 1px solid rgba(255, 255, 255, .4); border-bottom: 1px solid rgba(255, 255, 255, .4) }
.mybox01 tr:nth-child(odd) { background-color: rgba(250, 249, 244, .16) }
.mybox02 { width: 100%; border-collapse: collapse }
.mybox02 th { width: 32%; padding: 8px; border-bottom: 1px solid rgba(255, 255, 255, .4); border-top: 1px solid rgba(255, 255, 255, .4); background-color: rgba(250, 249, 244, .16); text-align: left; font-size: 92.857% }
.mybox02 td { padding: 8px; border-bottom: 1px solid rgba(255, 255, 255, .4); border-top: 1px solid rgba(255, 255, 255, .4) }
.mybox03 { width: 100%; border-collapse: separate; border-spacing: 0 12px }
.mybox03 th { width: 32%; padding: 8px; text-align: left; color: #fff; font-size: 92.857%; border: none; border-top-left-radius: 4px; border-bottom-left-radius: 4px; background-color: rgba(61, 145, 255, .88) }
.mybox03 td { padding: 8px; border-top-right-radius: 4px; border-bottom-right-radius: 4px; border-top: 1px solid rgba(255, 255, 255, .4); border-right: 1px solid rgba(255, 255, 255, .4); border-bottom: 1px solid rgba(255, 255, 255, .4) }
.mybox04 { width: 100%; border-collapse: collapse }
.mybox04 th { padding: 8px; background-color: rgba(250, 249, 244, .16); text-align: left; font-size: 92.857%; border: 1px solid rgba(255, 255, 255, .4) }
.mybox04 td { padding: 8px; border: 1px solid rgba(255, 255, 255, .4) }
.mybox05outer { overflow-x: scroll; -webkit-overflow-scrolling: touch; padding-bottom: 18px }
.mybox05 { width: 100%; border-collapse: collapse; white-space: nowrap }
.mybox05 th { padding: 8px; background-color: rgba(250, 249, 244, .16); text-align: left; font-size: 92.857%; border: 1px solid rgba(255, 255, 255, .4) }
.mybox05 td { padding: 8px; border: 1px solid rgba(255, 255, 255, .4) }
.mybox05notice { text-align: center; font-size: 85.714%; margin-top: 4px; color: #888 }
.floatl { clear: both; float: left; margin: 0 16px 8px 0 }
.floatr { clear: both; float: right; margin: 0 0 8px 16px }
.max40 { max-width: 40% }
.max100 { max-width: 100% }
figure { margin: 0; display: inline-block }
figure img { max-width: 100% }
figcaption { text-align: center; margin-top: 4px }
h1, h2, h3, h4 { line-height: 1.333; margin: 0 }
h1 { font-size: 100%; font-weight: normal }
h2 { font-size: 128.5714%; font-weight: 500 }
h3 { font-size: 114.2857%; font-weight: 500 }
h4 { font-size: 107.1429%; font-weight: 500 }
p ~ p { margin-top: 2.4248rem }
.h201 { border-bottom: 3px solid #fff; position: relative; padding-bottom: 6px }
.h201::first-letter { font-size: 133.3333% }
.h201::after { border-bottom: 3px solid rgb(61, 145, 255); content: ''; position: absolute; bottom: -3px; width: 38.2%; height: 3px; left: 0 }
.h202 { border-left: 3px solid rgb(61, 145, 255); padding-left: 6px }
.h202::first-letter { font-size: 133.3333% }
.h203 { border-left: 3px solid rgb(61, 145, 255); padding-left: 6px }
.h203 .textj { display: block }
.h203 .textj::first-letter { font-size: 133.3333% }
.h203 .texte { font-family: 'Fira Sans Extra Condensed', 'Noto Sans JP', sans-serif; font-weight: 400; font-size: 66.6667%; display: block; margin-top: 4px; border-top: 3px solid #fff; padding-top: 4px }
.h204, .h205 { padding: 2px 0 }
.h204::first-letter, .h205::first-letter { font-size: 133.3333%; background-color: rgb(61, 145, 255); color: #fff; margin-right: 2px; padding: 0 4px; display: inline-block; line-height: 1.1 }
.h206 { white-space: nowrap; text-align: center; display: inline-block }
.h206 .texte { display: flex; align-items: center; font-weight: 400; font-size: 55.5556%; font-family: 'Fira Sans Extra Condensed', sans-serif; letter-spacing: 1px; text-transform: uppercase }
.h206 .texte::before, .h206 .texte::after { border-top: 1px solid #fff; content: ''; flex-grow: 1; display: inline-block }
.h206 .texte::before { margin-right: 6px }
.h206 .texte::after { margin-left: 6px }
.h206 .textj { display: block; margin-top: 8px; font-size: 122.2222% }
.h207 { white-space: nowrap; text-align: center; position: relative; padding-bottom: 16px }
.h207 .textj { display: block; font-size: 122.2222% }
.h207 .texte { font-weight: 400; font-size: 55.5556%; font-family: 'Fira Sans Extra Condensed', sans-serif; display: block; letter-spacing: 1px; margin-top: 8px; text-transform: uppercase }
.h207::after { border-bottom: 3px solid rgba(61, 145, 255, 1); content: ''; position: absolute; bottom: 0; width: 40px; height: 3px; left: 50%; margin-left: -20px }
.h208 { border-bottom: 1px solid rgb(61, 145, 255); position: relative; padding-bottom: 12px; overflow: hidden }
.h208::after { content: ''; width: 100%; height: 3px; background-color: rgb(61, 145, 255); display: block; position: absolute; left: 0; bottom: 2px }
.h208 .textj { display: block }
.h208 .textj::first-letter { font-size: 133.3333% }
.h208 .texte { display: block; font-family: 'Fira Sans Extra Condensed', 'Noto Sans JP', sans-serif; font-size: 66.6667%; color: #888; font-weight: 400; margin-top: 2px }
.h209 { color: rgb(61, 145, 255) }
.h209::first-letter { font-size: 133.3333% }
.h301 { border-bottom: 1px solid rgba(255, 255, 255, .4); padding-bottom: 8px }
.h301 i { color: rgb(61, 145, 255) }
.h302 { background-color: rgb(61, 145, 255); padding: 4px; border: 1px solid #fff }
.h303, .h304 { padding: 2px 0 }
.h303::first-letter, .h304::first-letter { font-size: 125%; background-color: rgb(61, 145, 255); color: #fff; margin-right: 2px; padding: 0 3px; display: inline-block }
.h305 { border-left: 3px solid rgb(61, 145, 255); padding-left: 6px }
.h306 { color: rgb(61, 145, 255) }
h4 span { border-bottom: 4px double rgb(61, 145, 255); display: inline-block; padding-bottom: 4px }
.h401 { padding: 2px 0; margin-bottom: 8px }
.h401::first-letter { font-size: 125%; background-color: rgb(61, 145, 255); color: #fff; margin-right: 2px; padding: 0 2px; display: inline-block }
.h402 { background-color: rgba(61, 145, 255, .88); color: #fff; padding: 1px 8px 4px; font-weight: 500; margin-bottom: 8px }
.h403 { color: rgb(61, 145, 255) }
.mycontacttitle { border-top: 1px solid rgba(255, 255, 255, .4); padding: 8px 0; text-align: center; font-weight: 500; border-bottom: 1px solid rgba(255, 255, 255, .4); font-size: 107.1429%; margin-top: 24px }
.mycontactphone { text-align: center; font-weight: 500; font-size: 200%; line-height: 1; padding-top: 16px }
.mycontacttext { padding-top: 8px; text-align: center }
.mycontactor { display: flex; align-items: center; padding-left: 32%; padding-right: 32%; margin-top: 12px; white-space: nowrap }
.mycontactor::before, .mycontactor::after { border-top: 1px solid #fff; content: ''; flex-grow: 1; display: inline-block }
.mycontactor::before { margin-right: 8px }
.mycontactor::after { margin-left: 8px }
.mycontactbtn { text-align: center; border-bottom: 1px solid rgba(255, 255, 255, .4); padding-bottom: 16px; margin-top: 16px }
.mycontactbtn a { display: inline-block; line-height: 1; text-decoration: none; padding: 8px 16px; transition: .3s; white-space: nowrap; font-weight: 500; border: 3px solid rgba(61, 145, 255, 1); color: rgba(255, 255, 255, 1); background-color: rgba(61, 145, 255, 1) }
.mycontactbtn a:hover { color: rgba(61, 145, 255, 1); background-color: rgba(255, 255, 255, 1); text-decoration: none }
.mycontactbtn a::before { font-weight: 400; font-size: 128.5714%; line-height: 1; font-family: 'Font Awesome 5 Free'; content: '\f0e0\00a0' }
.myfaq dt { position: relative; color: #fff; padding: 8px 8px 8px 28px; line-height: 1; border: none; border-top-left-radius: 4px; border-top-right-radius: 4px; font-weight: 500; background-color: rgba(61, 145, 255, .88) }
.myfaq dt::before { position: absolute; font-size: 114.2857%; font-family: 'Font Awesome 5 Free'; left: 8px; top: 8px; content: '\f059' }
.myfaq dd { position: relative; padding: 8px 8px 8px 27px; border-right: 1px solid rgba(255, 255, 255, .4); border-bottom: 1px solid rgba(255, 255, 255, .4); border-left: 1px solid rgba(255, 255, 255, .4); border-bottom-left-radius: 4px; border-bottom-right-radius: 4px; background-color: #fff; color: #012036 }
.myfaq dd::before { position: absolute; font-size: 114.2857%; font-family: 'Font Awesome 5 Free'; left: 8px; top: 8px; content: '\f0a4' }
.mytalkiconl, .mytalkiconr { width: 64px }
.mytalkiconl img, .mytalkiconr img { width: 64px; height: auto }
.mytalktextl, .mytalktextr { width: calc(100% - 88px) }
.mytalkiconl { float: left; clear: both }
.mytalktextl { padding-left: 24px; float: right }
.mytalkiconr { float: right; clear: both }
.mytalktextr { padding-right: 24px; float: left }
.mytalkl01, .mytalkr01 { position: relative; border: 3px solid rgba(227, 227, 203, 1); padding: 16px; border-radius: 8px; width: calc(100% - 64px) }
.mytalkl02, .mytalkr02 { position: relative; border: 3px solid rgba(255, 168, 168, 1); padding: 16px; border-radius: 8px; width: calc(100% - 64px); background-color: rgba(255, 250, 250, 1); color: rgba(229, 0, 0, 1) }
.mytalkl01::after, .mytalkl01::before, .mytalkr01::after, .mytalkr01::before, .mytalkl02::after, .mytalkl02::before, .mytalkr02::after, .mytalkr02::before { top: 32px; border: solid transparent; content: ' '; height: 0; width: 0; position: absolute; pointer-events: none }
.mytalkl01, .mytalkl02 { float: left; clear: both }
.mytalkr01, .mytalkr02 { float: right; clear: both }
.mytalkl01::after, .mytalkl01::before, .mytalkl02::after, .mytalkl02::before { right: 100% }
.mytalkr01::after, .mytalkr01::before, .mytalkr02::after, .mytalkr02::before { left: 100% }
.mytalkl01::after, .mytalkr01::after, .mytalkl02::after, .mytalkr02::after { border-width: 9px; margin-top: -9px }
.mytalkl01::before, .mytalkr01::before, .mytalkl02::before, .mytalkr02::before { border-width: 14px; margin-top: -14px }
.mytalkl01::after { border-color: rgba(255, 255, 255, 0) rgba(255, 255, 255, 1) rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) }
.mytalkl01::before { border-color: rgba(255, 255, 255, 0); border-right-color: rgba(227, 227, 203, 1) }
.mytalkr01::after { border-color: rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) rgba(255, 255, 255, 1) }
.mytalkr01::before { border-color: rgba(255, 255, 255, 0); border-left-color: rgba(227, 227, 203, 1) }
.mytalkl02::after { border-color: rgba(255, 255, 255, 0) rgba(255, 250, 250, 1) rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) }
.mytalkl02::before { border-color: rgba(255, 255, 255, 0); border-right-color: rgba(255, 168, 168, 1) }
.mytalkr02::after { border-color: rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) rgba(255, 250, 250, 1) }
.mytalkr02::before { border-color: rgba(255, 255, 255, 0); border-left-color: rgba(255, 168, 168, 1) }
.mytalklfull { width: calc(100% - 38px) }
.mybtn02 a { display: inline-block; line-height: 1; color: rgb(61, 145, 255); text-decoration: none; padding: 10px 8px; border: 3px solid rgb(61, 145, 255); font-weight: 500; transition: .3s; background-color: #fff }
.mybtn02 a:hover { color: #fff; background-color: rgba(61, 145, 255, 1); text-decoration: none }
.mybtn02 a::before { font-family: 'Font Awesome 5 Free'; content: '\f054\00a0'; font-weight: 900 }
.mybtn03 a { display: inline-block; line-height: 1; color: #fff; text-decoration: none; padding: 10px 8px; border: 3px solid rgb(61, 145, 255); background-color: rgba(61, 145, 255, 1); font-weight: 500; transition: .3s }
.mybtn03 a:hover { color: rgb(61, 145, 255); background-color: #fff; text-decoration: none }
.mybtn03 a::before { font-family: 'Font Awesome 5 Free'; content: '\f054\00a0'; font-weight: 900 }
.mybtnnallow a { padding: 6px; font-size: 88% }
.div12 .myfadebanner div { font-size: 112% }
.div13 .myfadebanner div { font-size: 88% }
.div14 .myfadebanner div { font-size: 88% }
.mt00 { margin-top: 0 }
.mt08 { margin-top: 8px }
.mt16 { margin-top: 16px }
.mt24 { margin-top: 16px }
.mt32 { margin-top: 16px }
.mt40 { margin-top: 24px }
.mt56 { margin-top: 24px }
.mt72 { margin-top: 32px }
.mt88 { margin-top: 32px }
.mt120 { margin-top: 48px }
.mb00 { margin-bottom: 0 }
.mb08 { margin-bottom: 8px }
.mb16 { margin-bottom: 16px }
.mb24 { margin-bottom: 16px }
.mb32 { margin-bottom: 16px }
.mb40 { margin-bottom: 24px }
.mb56 { margin-bottom: 24px }
.mb72 { margin-bottom: 32px }
.mb88 { margin-bottom: 48px }
.mb120 { margin-bottom: 48px }
#pt { position: fixed; bottom: 0; right: 16px; display: none; width: 4rem; height: 4rem; background-image: url(../img/backpt.png); background-repeat: no-repeat; background-position: center center; background-color: rgb(2, 195, 230); background-size: 36px 36px }
#pt span { font-size: 4rem; display: block }
#pt a { color: rgb(2, 195, 230) }
}

@media (max-width: 452px) {
.div12 { width: calc(100% - 16px); max-width: 492px }
.div12border { width: calc(100% - 22px); max-width: 486px }
.div12c { text-align: center; font-size: 2.4rem; padding-top: 32px }
.div13 { width: calc(50% - 16px); max-width: 312px }
.div13border { width: calc(50% - 22px); max-width: 306px }
.div14 { width: calc(50% - 16px); max-width: 222px }
}

@media (min-width: 453px) and (max-width: 767px) {
.div12 { width: calc(50% - 16px); max-width: 492px }
.div12border { width: calc(50% - 22px); max-width: 486px }
.div12c { text-align: center; font-size: 4rem; padding-top: 80px }
.div13 { width: calc(50% - 16px); max-width: 312px }
.div13border { width: calc(50% - 22px); max-width: 306px }
.div14 { width: calc(50% - 16px); max-width: 222px }
}

@media (min-width: 768px) {
body { margin: 0; background-color: #094397; color: #fff; line-height: 1.732; font-size: 1.8rem; font-family: 'Noto Sans JP', sans-serif; font-feature-settings: 'palt' }
#hamicon, #drawernav, .smallonly { display: none }
#wrapper { position: relative; overflow: hidden; }
#containerheader { background-color: #012063; height: 91px; padding: 14px 0; overflow: hidden; }
header { width: 1216px; margin: 0 auto }
#headerl { width: 393px; float: left; clear: both }
#headerlogo { width: 393px; height: 34px; margin-top: 24px }
#headerr { width: 823px; float: right; white-space: nowrap }
#headerinfo { float: right; clear: both }
#headeropen { display: flex; line-height: 1; font-size: 1.7rem }
#headeropentitle { background-color: #fff; color: #012063; padding: 10px 6px 0; font-weight: 500 }
#headeropeninfo { margin: 0 14px 0 10px }
#headeropeninfo table { border-collapse: collapse }
#headerclosetitle { background-color: #fff; color: #012063; padding: 10px 6px 0; font-weight: 500 }
#headercloseinfo { padding-top: 10px; margin-left: 10px }
#headerphone { text-align: right; line-height: 1; margin-top: 10px }
#headerphone div { display: inline-block; font-size: 3.4rem; font-weight: 700; background-image: url(../img/back01.png); background-repeat: no-repeat; background-position: left 7px; padding-left: 34px }
#headerbtn { float: right; width: 232px; margin-right: 16px }
#headerbtn div { width: 235px; height: 40px; background-color: #fff; font-size: 0 }
#headerbtn div ~ div { margin-top: 8px }
#globalnav { width: 1216px; height: 77px; margin: 0 auto; overflow: visible }
.wcarea_40020A814601 #globalnav,.wcselect_40020A814601 #globalnav { height: auto }
#globalnav ul { padding: 0; list-style: none }
#globalnav li { display: block }
.dropnav { overflow: visible; display: flex; justify-content: center }
.dropnav-parent { display: block; position: relative; overflow: visible; margin: 0 22px; border-top: 4px solid rgba(2, 195, 230, 0)}
.dropnav-parent:hover { border-top: 4px solid rgba(2, 195, 230, 1) }
.dropnav-parent > a { color: #fff; text-decoration: none; font-size: 2.1rem; font-weight: 500; display: block; height: 59px; padding: 14px 8px 0; transition: .2s }
.dropnav-child { visibility: hidden; opacity: 0; z-index: 9999; position: absolute; top: 73px; left: 0; transition: .2s }
.dropnav-child li { display: block }
.dropnav-child a { display: block; background-color: rgba(1, 32, 99, 0.88); color: #fff; transition: .2s; text-decoration: none; padding: 8px 24px 8px 16px; white-space: nowrap; font-size: 88% }
.dropnav-child a:hover { background-color: rgba(2, 195, 230, 0.88); text-decoration: none }
.dropnav-child a::before { font-family: 'Font Awesome 5 Free'; content: '\f0da\00a0'; font-weight: 900 }
.dropnav-parent:hover .dropnav-child { visibility: visible; opacity: 1 }
#mainvisual { }
#mainvisual img { max-width: 100% }
#containerpagetitle { position: relative; height: 320px }
#pagetitleimg { width: 1920px; height: 320px; position: absolute; top: 0; left: 50%; margin-left: -960px; overflow: hidden; }
#pagetitlemask { width: 1920px; height: 320px; position: absolute; top: 0; left: 50%; margin-left: -960px }
#pagetitle { text-align: center; position: absolute; top: 80px; right: 0; left: 0; color: #fff; text-shadow: 1px 1px 1px #000 }
#pagetitlej { font-size: 5.6rem; font-weight: 700 }
#pagetitlee { font-family: 'Fira Sans Extra Condensed', sans-serif; font-size: 2.8rem; letter-spacing: 2px; font-weight: 400 }
#containermysec00outer { background-image: url(../img/back02.jpg); background-repeat: no-repeat; background-position: center 474px }
#containermysec00 { width: 1216px; margin: 0 auto }
#mysec00side { float: left; clear: both; width: 270px; background-color: #fff; padding: 14px }
#mysec00side h2 { font-family: 'Fira Sans Extra Condensed', sans-serif; color: #012063; font-size: 3.8rem; text-align: center; padding: 24px 0 16px; letter-spacing: 2px; font-weight: 500 }
.mysec00fadebanner { margin-top: 14px }
.mysec00fadebanner .myfadebanner div { font-weight: 700; font-size: 2.2rem }
.mysec00banner { font-size: 0; margin-top: 14px }
#mysec00main { width: 846px; float: right; margin-left: 72px; padding-top: 32px }
#mysec01 { background-image: url(../img/back03.png); background-repeat: no-repeat; background-position: left top }
#mysec01 h2 { font-family: 'Fira Sans Extra Condensed', sans-serif; color: #ceec4a; font-size: 7.4rem; letter-spacing: 2px; font-weight: 400; margin-bottom: 40px }
.mysec01info { margin-bottom: 16px }
.mysec01info dt { float: left; clear: both; width: 160px }
.mysec01info dd { float: right; width: 686px }
#mysec01btn { padding-top: 16px; text-align: right }
.mybtn05 a { display: inline-block; font-family: 'Fira Sans Extra Condensed', sans-serif; color: #ceec4a; font-size: 2.8rem; font-weight: 400; letter-spacing: 1px; text-decoration: none; padding-right: 8px; background-image: url(../img/back04.png); background-repeat: no-repeat; background-position: right bottom; background-size: 105px 4px; transition: .3s }
.mybtn05 a:hover { opacity: .72 }
#mysec02 { margin-top: 96px }
#mysec02 h2 { font-family: 'Fira Sans Extra Condensed', sans-serif; color: #ceec4a; font-size: 7.4rem; letter-spacing: 2px; font-weight: 400; margin-bottom: 24px }
#mysec02 p { font-size: 2.2rem; margin-bottom: 48px }
.mysec02box { width: 846px; height: 271px; position: relative; margin-bottom: 24px }
.mysec02img img { clip-path: polygon(76px 0, 0 271px, 479px 271px, 555px 0) }
.mysec02mobmask { display: none }
.mysec02mask { width: 555px; height: 271px; float: right; clear: both; position: absolute; top: 0; right: 0 }
#containerfooterouter { background-image: url(../img/back08.jpg); background-repeat: no-repeat; background-position: center 24px; padding-bottom: 80px; overflow: hidden; }
#containerfooter { overflow: hidden; }
footer { width: 1216px; margin: 0 auto; overflow: visible }
#footerh2 { overflow: visible }
#footerh2 h2 { font-family: 'Fira Sans Extra Condensed', sans-serif; color: #ceec4a; font-size: 7.4rem; letter-spacing: 2px; font-weight: 400; float: left; width: 340px; clear: both }
#footerh2line { float: right; width: 876px; overflow: visible }
#footerh2line span { display: block; border-bottom: 4px solid #fff; width: 1920px }
#footerimg { width: 634px; float: left; clear: both; margin-top: 16px }
#footerinfo { width: 542px; float: right; margin: 56px 0 0 40px }
.footerinfo { margin-bottom: 8px }
.footerinfo dt { width: 120px; float: left; clear: both }
.footerinfo dd { width: 422px; float: right }
#footerinfobtn { text-align: right; margin-top: 24px }
#navfooter { background-color: #fff; padding: 16px 0; overflow: hidden; }
#navfooter ul { display: flex; justify-content: center }
#navfooter li { display: block; padding: 0 16px; line-height: 1.1; font-size: 1.6rem }
#navfooter li:not(:first-child) { border-left: 1px solid #012036 }
#navfooter a { color: #012036; text-decoration: none; line-height: 1.1 }
#navfooter a:hover { opacity: .64 }
#footercopy { background-color: #101d27; text-align: center; color: #fff; font-size: 1.4rem; padding: 16px 0; overflow: hidden; }
main { margin-bottom: 56px }
#container { width: 1080px; margin: 32px auto 0; overflow: hidden; }
#topicpath { width: 1032px; font-size: 87.5%; margin: 0 24px }
#topicpath a { color: #fff; text-decoration: underline }
#topicpath a:hover { color: rgba(255, 255, 255, .4) }
#maincontents { width: 1080px; margin-top: 40px }
.sec1032 { width: 1032px; margin: 0 24px }
.center { text-align: center;}
.secflex { width: 1080px; display: flex }
.arrowh { text-align: center; font-size: 350%; line-height: 1 }
.div12 { width: 492px; margin: 0 24px 48px }
.div12flex { width: 516px; margin: 0 12px 48px; display: flex; flex-wrap: wrap }
.div12flex11 { width: 492px; margin: 0 12px 24px }
.div12flex12 { width: 234px; margin: 0 12px 24px }
.div12border { width: 486px; margin: 0 24px 48px; border: 3px solid rgba(61, 145, 255, .88) }
.divborderinner { padding: 16px 24px }
.div12 dd { padding: 16px 0 0 }
.div12l { width: 400px; margin-left: 24px; padding-top: 61px }
.div12c { text-align: center; font-size: 5.2rem; height: 192px; padding-top: 136px }
.div12r { width: 492px; margin-right: 24px }
.div12l dd, .div12r dd { padding: 16px 0 0 }
.div13 { width: 312px; margin: 0 24px 48px }
.div13border { width: 306px; margin: 0 24px 48px; border: 3px solid rgba(61, 145, 255, .88) }
.div13 dd { padding: 8px 0 0 }
.div14 { width: 222px; margin: 0 24px 48px }
.div14 dd { padding: 12px 0 0 }
.dl01 { width: 1032px; margin-bottom: 8px; padding-bottom: 8px; border-bottom: 1px solid rgba(255, 255, 255, .4) }
.dl01 dt { clear: both; float: left; width: 224px; padding-right: 16px; font-weight: bold }
.dl01 dd { float: right; width: 772px; padding-left: 16px; border-left: 4px solid rgba(255, 255, 255, .4) }
.dl02 { width: 672px; margin-bottom: 8px; padding-bottom: 8px; border-bottom: 1px solid rgba(255, 255, 255, .4) }
.dl02 dt { clear: both; float: left; width: 152px; padding-right: 16px; font-weight: bold }
.dl02 dd { float: right; width: 484px; padding-left: 16px; border-left: 4px solid rgba(255, 255, 255, .4) }
.mylist01img { width: 312px; float: left; clear: both }
.mylist01 { width: 672px; margin-left: 48px; float: right }
.mylist02img { width: 312px; float: right; clear: both }
.mylist02 { width: 672px; margin-right: 48px; float: left }
.mylist03 { padding-left: 32px }
.mylist03 li { margin-bottom: 8px }
.mylist04 { list-style: none; padding-left: 8px }
.mylist04 li { padding: 6px 0 0 28px; position: relative; margin-bottom: 8px }
.mylist04 li::before { position: absolute; font-family: 'Font Awesome 5 Free'; left: 0; top: 0; content: '\f0a4'; color: rgb(61, 145, 255); font-size: 150% }
.mybox01 { width: 100%; border-collapse: collapse }
.mybox01 th { width: 24%; padding: 8px 16px; border-top: 1px solid rgba(255, 255, 255, .4); border-bottom: 1px solid rgba(255, 255, 255, .4); text-align: left; font-size: 87.5% }
.mybox01 td { padding: 8px 16px; border-top: 1px solid rgba(255, 255, 255, .4); border-bottom: 1px solid rgba(255, 255, 255, .4) }
.mybox01 tr:nth-child(odd) { background-color: rgba(250, 249, 244, .16) }
.mybox02 { width: 100%; border-collapse: collapse }
.mybox02 th { width: 24%; padding: 8px 16px; border-bottom: 1px solid rgba(255, 255, 255, .4); border-top: 1px solid rgba(255, 255, 255, .4); background-color: rgba(250, 249, 244, .16); text-align: left; font-size: 87.5% }
.mybox02 td { padding: 8px 16px; border-bottom: 1px solid rgba(255, 255, 255, .4); border-top: 1px solid rgba(255, 255, 255, .4) }
.mybox03 { width: 100%; border-collapse: separate; border-spacing: 0 16px }
.mybox03 th { width: 24%; padding: 8px 16px; text-align: left; color: #fff; font-size: 87.5%; border: 1px solid rgba(61, 145, 255, .88); border-top-left-radius: 4px; border-bottom-left-radius: 4px; background-color: rgba(61, 145, 255, .88) }
.mybox03 td { padding: 8px 16px; border-top-right-radius: 4px; border-bottom-right-radius: 4px; border-top: 1px solid rgba(255, 255, 255, .4); border-right: 1px solid rgba(255, 255, 255, .4); border-bottom: 1px solid rgba(255, 255, 255, .4) }
.mybox04 { width: 100%; border-collapse: collapse }
.mybox04 th { padding: 8px 16px; background-color: rgba(250, 249, 244, .16); text-align: left; font-size: 87.5%; border: 1px solid rgba(255, 255, 255, .4) }
.mybox04 td { padding: 8px 16px; border: 1px solid rgba(255, 255, 255, .4) }
.mybox05outer { overflow-x: scroll; -webkit-overflow-scrolling: touch; padding-bottom: 16px }
.mybox05 { border-collapse: collapse; ; white-space: nowrap }
.mybox05 th { padding: 8px 16px; background-color: rgba(250, 249, 244, .16); text-align: left; font-size: 87.5%; border: 1px solid rgba(255, 255, 255, .4) }
.mybox05 td { padding: 8px 16px; border: 1px solid rgba(255, 255, 255, .4) }
.mybox05notice { text-align: center; font-size: 81.25%; margin-top: 8px; color: #888 }
.floatl { clear: both; float: left; margin: 0 48px 16px 0 }
.floatr { clear: both; float: right; margin: 0 0 16px 48px }
.max100 { max-width: 100% }
figure { margin: 0; display: inline-block }
figure img { max-width: 100% }
figcaption { text-align: center; margin-top: 8px }
h2, h3, h4 { line-height: 1.1; margin: 0 }
h1 { font-size: 87.5%; font-weight: 400; line-height: 1; margin: 0 }
h2 { font-size: 175%; font-weight: 500 }
h3 { font-size: 137.5%; font-weight: 500 }
h4 { font-size: 112.5%; font-weight: 500 }
p ~ p { margin-top: 2.7712rem }
.h201 { border-bottom: 4px solid #fff; position: relative; padding-bottom: 16px }
.h201::first-letter { font-size: 121.429% }
.h201::after { border-bottom: 4px solid rgb(61, 145, 255); content: ''; position: absolute; bottom: -4px; width: 38.2%; height: 4px; left: 0 }
.h202 { border-left: 4px solid rgb(61, 145, 255); padding-left: 12px }
.h202::first-letter { font-size: 121.429% }
.h203 { border-left: 4px solid rgb(61, 145, 255); padding-left: 12px }
.h203 .textj { display: block }
.h203 .textj::first-letter { font-size: 121.429% }
.h203 .texte { font-family: 'Fira Sans Extra Condensed', 'Noto Sans JP', sans-serif; font-weight: 400; font-size: 53.5714%; display: block; margin-top: 12px; border-top: 3px solid rgba(255, 255, 255, .4); padding-top: 8px }
.h204 { padding: 4px 0 6px; border-bottom: 3px solid rgb(61, 145, 255) }
.h205 { padding: 4px 0 6px }
.h204::first-letter, .h205::first-letter { font-size: 121.429%; background-color: rgb(61, 145, 255); color: #fff; margin-right: 4px; padding: 0 5px; display: inline-block }
.h206 { text-align: center; display: inline-block }
.h206 .texte { display: flex; align-items: center; font-weight: 400; font-size: 39.286%; font-family: 'Fira Sans Extra Condensed', sans-serif; letter-spacing: 1px; text-transform: uppercase }
.h206 .texte::before, .h206 .texte::after { border-top: 1px solid #fff; content: ''; flex-grow: 1; display: inline-block }
.h206 .texte::before { margin-right: 8px }
.h206 .texte::after { margin-left: 8px }
.h206 .textj { display: block; margin-top: 16px; font-size: 121.429% }
.h207 { white-space: nowrap; text-align: center; position: relative; padding-bottom: 24px }
.h207 .textj { display: block; font-size: 121.429% }
.h207 .texte { font-weight: 400; font-size: 39.286%; font-family: 'Fira Sans Extra Condensed', sans-serif; display: block; letter-spacing: 1px; margin-top: 16px; text-transform: uppercase }
.h207::after { border-bottom: 4px solid rgb(61, 145, 255); content: ''; position: absolute; bottom: 0; width: 40px; height: 4px; left: 50%; margin-left: -20px }
.h208 { border-bottom: 1px solid rgb(61, 145, 255); position: relative; padding-bottom: 20px; overflow: hidden }
.h208::after { content: ''; width: 100%; height: 4px; background-color: rgb(61, 145, 255); display: block; position: absolute; left: 0; bottom: 3px }
.h208 .textj { display: block; float: left; clear: both }
.h208 .textj::first-letter { font-size: 121.429% }
.h208 .texte { display: block; float: right; font-family: 'Fira Sans Extra Condensed', 'Noto Sans JP', sans-serif; font-size: 53.5714%; color: #888; font-weight: 400; text-align: right; margin-top: 20px }
.h209 { color: rgb(61, 145, 255) }
.h209::first-letter { font-size: 121.429% }
.h301 { border-bottom: 1px solid rgba(255, 255, 255, .4); padding-bottom: 12px }
.h301 i { color: rgb(61, 145, 255) }
.h302 { background-color: rgb(61, 145, 255); padding: 8px; border: 1px solid #fff }
.h303 { padding: 4px 0; border-bottom: 2px solid rgb(61, 145, 255) }
.h304 { padding: 4px 0 }
.h303::first-letter, .h304::first-letter { font-size: 118.1818%; background-color: rgb(61, 145, 255); color: #fff; margin-right: 4px; padding: 0 4px; display: inline-block }
.h305 { border-left: 3px solid rgb(61, 145, 255); padding-left: 8px }
.h306 { color: rgb(61, 145, 255) }
h4 span { border-bottom: 4px double rgb(61, 145, 255); display: inline-block; padding-bottom: 8px }
.h401 { padding: 4px 0; border-bottom: 1px solid rgb(61, 145, 255); margin-bottom: 16px }
.h401::first-letter { font-size: 133.3333%; background-color: rgb(61, 145, 255); color: #fff; margin-right: 4px; padding: 0 4px; display: inline-block }
.h402 { background-color: rgba(61, 145, 255, .88); color: #fff; padding: 5px 16px 8px; font-weight: 500; margin-bottom: 16px }
.h403 { color: rgb(61, 145, 255) }
.mycontacttitle { border-top: 1px solid rgba(255, 255, 255, .4); padding: 16px 0; text-align: center; font-weight: 500; border-bottom: 1px solid rgba(255, 255, 255, .4); font-size: 106.25%; margin-top: 40px }
.mycontactphone { text-align: center; font-weight: 500; font-size: 200%; line-height: 1; padding-top: 16px }
.mycontacttext { padding-top: 8px; text-align: center }
.mycontactor { display: flex; align-items: center; font-size: 87.5%; padding: 0 40%; margin-top: 12px }
.mycontactor::before, .mycontactor::after { border-top: 1px solid #fff; content: ''; flex-grow: 1; display: inline-block }
.mycontactor::before { margin-right: 8px }
.mycontactor::after { margin-left: 8px }
.mycontactbtn { text-align: center; border-bottom: 1px solid rgba(255, 255, 255, .4); padding-bottom: 24px; margin-top: 16px }
.mycontactbtn a { display: inline-block; line-height: 1; text-decoration: none; padding: 12px 24px; transition: .3s; white-space: nowrap; font-weight: 500; border: 3px solid rgba(61, 145, 255, 1); color: rgba(255, 255, 255, 1); background-color: rgba(61, 145, 255, 1) }
.mycontactbtn a:hover { color: rgba(61, 145, 255, 1); background-color: rgba(255, 255, 255, 1); text-decoration: none }
.mycontactbtn a::before { font-size: 125%; font-family: 'Font Awesome 5 Free'; content: '\f0e0\00a0'; font-weight: 400 }
.myfaq dt { position: relative; color: #fff; padding: 10px 16px 10px 40px; line-height: 1; border: none; border-top-left-radius: 4px; border-top-right-radius: 4px; font-weight: 500; background-color: rgba(61, 145, 255, .88) }
.myfaq dt::before { position: absolute; font-size: 112.5%; font-family: 'Font Awesome 5 Free'; left: 16px; top: 10px; content: '\f059' }
.myfaq dd { position: relative; padding: 12px 16px 16px 40px; border-right: 1px solid rgba(255, 255, 255, .4); border-bottom: 1px solid rgba(255, 255, 255, .4); border-left: 1px solid rgba(255, 255, 255, .4); border-bottom-left-radius: 4px; border-bottom-right-radius: 4px; background-color: #fff; color: #012036 }
.myfaq dd::before { position: absolute; font-size: 112.5%; font-family: 'Font Awesome 5 Free'; left: 16px; top: 12px; content: '\f0a4' }
.mytalkiconl, .mytalkiconr { width: 104px }
.mytalktextl, .mytalktextr { width: 904px }
.mytalkiconl { float: left; clear: both }
.mytalktextl { padding-left: 24px; float: right }
.mytalkiconr { float: right; clear: both }
.mytalktextr { padding-right: 24px; float: left }
.mytalkl01, .mytalkr01 { position: relative; border: 3px solid rgba(227, 227, 203, 1); padding: 16px; border-radius: 8px; width: calc(100% - 166px) }
.mytalkl02, .mytalkr02 { position: relative; border: 3px solid rgba(255, 168, 168, 1); padding: 16px; border-radius: 8px; width: calc(100% - 166px); background-color: rgba(255, 250, 250, 1); color: rgba(229, 0, 0, 1) }
.mytalkl01::after, .mytalkl01::before, .mytalkr01::after, .mytalkr01::before, .mytalkl02::after, .mytalkl02::before, .mytalkr02::after, .mytalkr02::before { top: 32px; border: solid transparent; content: ' '; height: 0; width: 0; position: absolute; pointer-events: none }
.mytalkl01, .mytalkl02 { float: left; clear: both }
.mytalkr01, .mytalkr02 { float: right; clear: both }
.mytalkl01::after, .mytalkl01::before, .mytalkl02::after, .mytalkl02::before { right: 100% }
.mytalkr01::after, .mytalkr01::before, .mytalkr02::after, .mytalkr02::before { left: 100% }
.mytalkl01::after, .mytalkr01::after, .mytalkl02::after, .mytalkr02::after { border-width: 9px; margin-top: -9px }
.mytalkl01::before, .mytalkr01::before, .mytalkl02::before, .mytalkr02::before { border-width: 14px; margin-top: -14px }
.mytalkl01::after { border-color: rgba(255, 255, 255, 0) rgba(255, 255, 255, 1) rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) }
.mytalkl01::before { border-color: rgba(255, 255, 255, 0); border-right-color: rgba(227, 227, 203, 1) }
.mytalkr01::after { border-color: rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) rgba(255, 255, 255, 1) }
.mytalkr01::before { border-color: rgba(255, 255, 255, 0); border-left-color: rgba(227, 227, 203, 1) }
.mytalkl02::after { border-color: rgba(255, 255, 255, 0) rgba(255, 250, 250, 1) rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) }
.mytalkl02::before { border-color: rgba(255, 255, 255, 0); border-right-color: rgba(255, 168, 168, 1) }
.mytalkr02::after { border-color: rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) rgba(255, 255, 255, 0) rgba(255, 250, 250, 1) }
.mytalkr02::before { border-color: rgba(255, 255, 255, 0); border-left-color: rgba(255, 168, 168, 1) }
.mytalklfull { width: calc(100% - 38px) }
.mybtn02 a { display: inline-block; line-height: 1; color: rgb(61, 145, 255); text-decoration: none; padding: 12px 24px; border: 3px solid rgb(61, 145, 255); font-weight: 500; transition: .3s; background-color: #fff }
.mybtn02 a:hover { color: #fff; background-color: rgba(61, 145, 255, 1); text-decoration: none }
.mybtn02 a::before { font-family: 'Font Awesome 5 Free'; content: '\f054\2003'; font-weight: 900 }
.mybtn03 a { display: inline-block; line-height: 1; color: #fff; text-decoration: none; padding: 12px 24px; border: 3px solid rgb(61, 145, 255); background-color: rgba(61, 145, 255, 1); font-weight: 500; transition: .3s }
.mybtn03 a:hover { color: rgb(61, 145, 255); background-color: #fff; text-decoration: none }
.mybtn03 a::before { font-family: 'Font Awesome 5 Free'; content: '\f054\2003'; font-weight: 900 }
.mybtnnallow a { padding: 6px; font-size: 88% }
.div12 .myfadebanner div { font-size: 120% }
.div13 .myfadebanner div { font-size: 104% }
.div14 .myfadebanner div { font-size: 88% }
.mt00 { margin-top: 0 }
.mt08 { margin-top: 8px }
.mt16 { margin-top: 16px }
.mt24 { margin-top: 24px }
.mt32 { margin-top: 32px }
.mt40 { margin-top: 40px }
.mt56 { margin-top: 56px }
.mt72 { margin-top: 72px }
.mt88 { margin-top: 88px }
.mt120 { margin-top: 120px }
.mb00 { margin-bottom: 0 }
.mb08 { margin-bottom: 8px }
.mb16 { margin-bottom: 16px }
.mb24 { margin-bottom: 24px }
.mb32 { margin-bottom: 32px }
.mb40 { margin-bottom: 40px }
.mb56 { margin-bottom: 56px }
.mb72 { margin-bottom: 72px }
.mb88 { margin-bottom: 88px }
.mb120 { margin-bottom: 120px }
.largetac { text-align: center }
#pt { position: fixed; bottom: 16px; right: 16px; display: none; width: 4.8rem; height: 4.8rem; background-image: url(../img/backpt.png); background-repeat: no-repeat; background-position: center center; background-color: rgb(2, 195, 230); border-radius: 2px; border: none }
#pt span { font-size: 4.8rem; display: block }
#pt a { color: rgb(2, 195, 230) }
.h492 { height: 492px; padding-top: 0 }
}


/* ショッピングガイド */

.sptxt{
    display: none
}

.wcedit_40020A814601 .sptxt{
     display: block !important
}

@media screen and (max-width:768px){
    .tbscroll{
        width: 100%;
        overflow-x:scroll !important;
    }
    
    .tbscroll .mybox04{
        width: 600px;
    }
    
    .tbscroll .mybox04 th{
        width: 66px;

    }
    .sptxt{
    display: block;
        font-size: 12px;
}
    
    
}


/* wcshop調整用　*/

/* --- パンくずリンク色 --- */
#shp3_wrapper #topicpath #list_header_menu a {
    color: #337ab7 !important;
    text-decoration: none;
}

/* --- 文字サイズ --- */

body #shp3_wrapper{
    font-size: 17px;
} 

@media screen and (max-width: 767px) {
 body #shp3_wrapper{
    font-size: 15px;
}    
}

#shp3_wrapper .shp3_member_link a {
    font-size: 14px !important;
   
}
#shp3_wrapper .category-nav a {
       font-size: 14px !important;
   
}

#shp3_wrapper .category-nav ul > li > a {
    padding-left: 25px !important;
    font-size: 13px !important;
}

#shp3_wrapper .shp3_item_name {
    font-size: 14px !important;
}

#shp3_wrapper #shp3_item_detail_area .shp3_item_detail .sale_price {
    font-size: 28px !important;
}

/* --- カートの中身　ポップアップ --- */

#shp3_wrapper .shp3_cart .shp3_item_box .shp3_item_detail {
    padding-left: 8px !important;
}
#shp3_wrapper .shp3_cart .shp3_item_box .shp3_item_price {
    font-size: 15px !important;
}

@media screen and (min-width: 768px){
    #shp3_wrapper .total_box dl.total_price dd {
    font-size: 15px !important;
    padding-top: 5px !important;
}
#shp3_wrapper .shp3_btn {
    font-size: 13px !important    
}
    
#shp3_wrapper .form-control {
    font-size: 14px !important; 
}    
    
}
#shp3_wrapper dl.shp3_quantity dt {
    padding-left: 5px !important;
}

#shp3_wrapper form dt::before {
   display: none !important;
}


