@charset "utf-8";

@font-face { font-family: 'Font Awesome 6 Free'; font-style: normal; font-weight: 900; font-display: block; src: url('/data/common/c2101a089201/css/fontawesome/webfonts/fa-solid-900.woff2') format('woff2'), url('/data/common/c2101a089201/css/fontawesome/webfonts/fa-solid-900.ttf') format('truetype') }

:root { --basecolor: 229, 0, 18 }
:root { --textcolor: 0, 0, 0 }
:root { --linkcolor: 0, 0, 0 }
:root { --bordercolor: 221, 221, 221 }
:root { --blogcolor: 26, 115, 232 }
:root { --subcolor: 255, 112, 67 }

.cmshtml { scroll-behavior: smooth }
.cmshtml * { box-sizing: border-box; -webkit-tap-highlight-color: transparent }
.cmshtml body { margin: 0; background-color: #fff; color: rgb(var(--textcolor)); font-size: clamp(15px, calc(0.142vw + 14.47px), 16px); font-family: 'Noto Sans JP', sans-serif; line-height: 1.732 }
.cmshtml section, div, dl { display: flow-root }
.cmshtml p { margin: 0 }
.cmshtml a { color: rgb(var(--linkcolor)); text-decoration: none }
.cmshtml a:hover { color: #000; text-decoration: underline }
.cmshtml :is(ul, ol, dl, dt, dd) { margin: 0; padding: 0 }
.cmshtml :is(h1, h2, h3, h4, h5, h6) { margin: 0 }
.cmshtml img { border: none; vertical-align: top }
.cmshtml a img { transition: .3s }
.cmshtml a:hover img { opacity: .72 }
.cmshtml #wrapper img { height: auto }
.cmshtml mark { background: linear-gradient(transparent 64%, #ffdfef 64%); color: #000; padding: 0 1px 1px }
.cmshtml label { display: block; caret-color: transparent }
.cmshtml :is(input[type='text'], input[type='file'], input[type='email'], input[type='tel'], input[type='number'], input[type='date'], input[type='password'], textarea, select) { border: 2px solid #ddd !important; transition: .3s !important; outline: none }
.cmshtml :is(input[type='text'], input[type='file'], input[type='email'], input[type='tel'], input[type='number'], input[type='date'], input[type='password'], textarea, select):focus { border-color: #1b95e0 !important; box-shadow: none !important }
.cmshtml form dl { background-color: rgb(250, 249, 244); border: 1px solid rgb(239, 237, 222); border-radius: 8px; padding: 8px 16px !important }
.cmshtml form dt { margin-bottom: 4px !important; font-size: 92% }
.cmshtml .contact_item_title::before { font-family: 'Font Awesome 6 Free'; content: '\f0da\00a0'; font-weight: 900 }
.cmshtml form dt span { color: #fff; font-weight: 400; font-size: 75%; line-height: 1.1; padding: 1px 4px 3px; border-radius: 4px; border: none; background-color: #f90; display: inline-block; margin-left: 8px }
.cmshtml form dd { margin-top: 12px }
.cmshtml textarea { width: calc(100% - 14px) }
.cmshtml .contact_item_title:not(:first-child) { margin-top: 16px !important }
.cmshtml caption { caption-side: bottom; font-size: 88%; margin-top: 8px; color: #777 }
.cmshtml figure img { max-width: 100% }
.cmshtml figcaption { text-align: center; font-size: 88%; margin-top: 8px }
.cmshtml table { border-collapse: collapse }
.cmshtml iframe { border: none }

@keyframes myFadein { 0% { opacity: 0; transform: scale(.8) }
24% { opacity: 1 }
100% { transform: scale(1) }
}

@-moz-document url-prefix() {
:root { --mypadding: 0px }
}

@media not all and (min-resolution: 0.001dpcm) {
@supports (-webkit-appearance: none) {
:root { --mypadding: 15px }
}
}

@supports (-webkit-appearance: none) and (not (-moz-appearance: none)) {
:root { --mypadding: 15px }
@media (forced-colors: active) {
:root { --mypadding: 15px }
}
}

@media (max-width: 1079px) {
.cmsbody { font-feature-settings: 'palt'; -webkit-text-size-adjust: 100% }
.cmshtml :is(h1, .largeonly) { display: none }
.cmshtml #wrapper { position: relative }
.cmshtml #header_corp { height: 66px; padding: 10px }
.cmshtml #headerlogo_corp { width: 42% }
.cmshtml #headerlogo_corp img { max-width: 100% }
.cmshtml #globalnav_corp { display: none }
.cmshtml #mainvisual { position: relative; margin-top: -66px; z-index: -1 }
.cmshtml #mainvisual img { width: 100%; height: 300px !important; object-fit: cover; animation: myFadein 2s ease 0s }
.cmshtml #containerpagetitle_corp { position: relative; margin-top: -66px; z-index: -1 }
.cmshtml #pagetitleimg_corp img { width: 100%; height: 200px !important; object-fit: cover }
.cmshtml #pagetitleouter_corp { position: absolute; top: 0; right: 0; bottom: 0; left: 0; display: flex; justify-content: center; align-items: center }
.cmshtml #pagetitle_corp { color: #fff; text-align: center; text-shadow: 0 0 5px #000; line-height: 1.5 }
.cmshtml #pagetitle_corp dt { font-size: 30px; font-weight: 600 !important; letter-spacing: 3px }
.cmshtml #pagetitle_corp dd { font-size: 18px; font-weight: 400 !important; letter-spacing: 2px }
.cmshtml #maincontents_corp { margin: 32px 0 56px }
.cmshtml #mainvisualticker { }
.cmshtml #mainvisualtickertitle { background-color: #e50012; text-align: center }
.cmshtml #mainvisualtickertitle img { width: 150px }
.cmshtml .mynewarticles { padding: 16px 40px }
.cmshtml #mainvisualtickertitlebtn { text-align: center }
.cmshtml #mainvisualtickertitlebtn a { display: inline-block; text-decoration: none; color: #000; font-weight: 600; font-size: 15px; background: url(../img/corp/back03.png) 90% center / 25px 24px no-repeat; min-height: 24px; padding-right: 48px }
.cmshtml .containermysection01 { padding: 0 16px; margin-top: 24px }
.cmshtml .mysection01 { }
.cmshtml .mysection01 > div:nth-of-type(1) { }
.cmshtml .mysection01 > div:nth-of-type(2) { margin-top: 24px; text-align: center }
.cmshtml .mysection01titleen { font-size: clamp(64px, calc(5.674vw + 42.72px), 104px); font-weight: 600; color: transparent; -webkit-text-stroke: 1px rgb(var(--basecolor)); text-stroke: 1px rgb(var(--basecolor)); letter-spacing: -2px; line-height: 1 }
.cmshtml .mysection01title { margin-top: clamp(8px, calc(2.27vw + -0.51px), 24px) }
.cmshtml .mysection01title h2 { font-size: clamp(24px, calc(0.567vw + 21.87px), 28px); font-weight: 330; letter-spacing: clamp(4px, calc(0.284vw + 2.94px), 6px); line-height: 1.3 }
.cmshtml .mysection01title i { font-size: clamp(36px, calc(1.702vw + 29.62px), 48px); font-style: normal; font-weight: 350; letter-spacing: clamp(1px, calc(0.284vw + -0.06px), 3px) }
.cmshtml .mysection01text { color: #4d4d4d; margin-top: clamp(16px, calc(1.135vw + 11.74px), 24px); line-height: 1.8 }
.cmshtml .mysection01img img { max-width: 100% }
.cmshtml .containermysection02 { margin-top: clamp(64px, calc(3.404vw + 51.23px), 88px) }
.cmshtml .containermysection03 { margin-top: clamp(64px, calc(3.404vw + 51.23px), 88px) }
.cmshtml .mysection02img img { width: 100%; height: 200px !important; object-fit: cover }
.cmshtml .mysection02outer { margin-top: -56px }
.cmshtml .mysection03outer { margin-top: -56px }
.cmshtml .mysection02 { padding: 0 16px; position: relative; z-index: 2 }
.cmshtml .mysection03 { padding: 0 16px; position: relative; z-index: 2 }
.cmshtml .mysection02title { margin-top: 0px }
.cmshtml .mysection03title { margin-top: 0px; text-align: right }
.cmshtml :is(.mysection02title, .mysection03title) h2 { font-size: clamp(20px, calc(1.135vw + 15.74px), 28px); color: #fff; line-height: 1.2; letter-spacing: 8px; font-weight: 400; text-shadow: 0 0 5px #000 }
.cmshtml :is(.mysection02title, .mysection03title) h3 { font-size: clamp(48px, calc(3.404vw + 35.23px), 72px); color: rgb(var(--basecolor)); line-height: 1; font-weight: 700 }
.cmshtml .mysection02banners { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 24px }
.cmshtml .mysection02banner { position: relative }
.cmshtml .mysection02banner img { max-width: 100% }
.cmshtml .mysection02bannertitle { background: url(../img/corp/back06.png) left 12px / 12px 3px no-repeat; padding-left: 17px }
.cmshtml .mysection02banner a { position: absolute; top: 0; right: 0; bottom: 0; left: 0 }
.cmshtml .mysection02btn { margin-top: 48px; text-align: center }
.cmshtml .mysection02btn a { display: inline-block; text-decoration: none; color: #fff; padding: 8px 56px 8px 40px; border-radius: 80px; background: url(../img/corp/back08.png) 88% center no-repeat #000; letter-spacing: 2px }
.cmshtml .containermysection04 { margin-top: 56px; padding: 40px 16px; background: url(../img/corp/back09.png) center bottom / 200% no-repeat #f7f7f7 }
.cmshtml .mysection04outer { position: relative }
.cmshtml .mysection04img { position: relative }
.cmshtml .mysection04img img { width: 100%; height: 200px !important; object-fit: cover }
.cmshtml .mysection04img::after { display: block; content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; border: 56px solid #f7f7f7; transition: .6s }
.cmshtml .mysection04img.is-show::after { border-width: 0 }
.cmshtml .mysection04inner { }
.cmshtml .mysection04 { border-left: 5px solid rgb(var(--basecolor)); background-color: #fff; padding: 24px; text-align: center }
.cmshtml .mysection04 dt { color: rgb(var(--basecolor)); font-weight: 600 !important; letter-spacing: 1px }
.cmshtml .mysection04 dd { font-size: clamp(26px, calc(0.851vw + 22.81px), 32px); font-weight: 350 !important; letter-spacing: 4px; line-height: 1.4 }
.cmshtml .mysection04text { margin-top: 16px; font-weight: 330 }
.cmshtml .mysection04btn { margin-top: 16px }
.cmshtml .mysection04btn a { display: inline-block; text-decoration: none; color: #fff; padding: 8px 56px 8px 40px; border-radius: 80px; background: url(../img/corp/back08.png) 88% center no-repeat rgb(var(--basecolor)); letter-spacing: 2px }
.cmshtml #footer_corp { background: url(../img/corp/back10.jpg) center center / cover no-repeat; padding: 56px 16px }
.cmshtml .footerlogo_corp { text-align: center }
.cmshtml .footerlogo_corp img { max-width: 32% }
.cmshtml .footeraddress_corp { margin-top: 24px; text-align: center; color: #fff; font-size: 15px; letter-spacing: 1px }
.cmshtml .footeraddress_corp dt { font-weight: 330 !important }
.cmshtml .footeraddress_corp dd { font-weight: 330 !important; letter-spacing: 2px; margin-top: 8px }
.cmshtml .footeraddress_corp dd strong { font-size: 26px; font-weight: 330 !important }
.cmshtml .footeropeninfo_corp { text-align: center; color: #fff; margin-top: 16px }
.cmshtml .footeropeninfo_corp strong { display: inline-block; font-weight: 330; padding: 2px 32px; border: 1px solid #fff; font-size: 14px; letter-spacing: 1px }
.cmshtml .footersns_corp { display: flex; justify-content: center; column-gap: 8px; margin-top: 30px }
.cmshtml .footersns_corp > div { width: 41px !important }
.cmshtml .footernav_corp { display: none }
.cmshtml .footernavbox_corp { text-align: center; margin-top: 40px }
.cmshtml .footernavbox_corp a { display: inline-block; color: #fff; background-color: #e50112; padding: 2px 20px 3px; font-size: 12px !important; letter-spacing: 1px !important }
.cmshtml .footercopy_corp { font-size: 12px; color: #fff; text-align: center; background-color: #000; letter-spacing: 1px; padding: 10px }
.cmshtml .smalltac { text-align: center }
.cmshtml #pt { position: fixed; bottom: 16px; right: 8px; display: none; width: 48px; height: 48px; opacity: 0; transition: opacity 0.5s ease; z-index: 998 }
.cmshtml #pagetop_corp a { display: inline-block; color: #fff; text-decoration: none; padding: 10px; background-color: #1d91ac; border-radius: 5px; font-size: 23px; line-height: 1; transition: .3s }
.cmshtml #pagetop_corp a:hover { background-color: #8bc53f }
.cmshtml #mydrawerhambergerouter { position: fixed; top: 0; right: 0; z-index: 9999; background-color: rgb(var(--basecolor)); padding: 3px 10px 12px 10px }
.cmshtml #mydrawertoggle { display: none }
.cmshtml #mydrawerhamberger { display: block; cursor: pointer }
.cmshtml #mydrawerhamberger span { display: block; background-color: #fff; transition: 0.4s; transform-origin: 0; width: 28px; height: 2px; margin-top: 8px }
.cmshtml #mydrawertoggle:checked + #mydrawerhamberger span:nth-child(1) { transform: translate(4px, 0) rotate(45deg) }
.cmshtml #mydrawertoggle:checked + #mydrawerhamberger span:nth-child(2) { opacity: 0 }
.cmshtml #mydrawertoggle:checked + #mydrawerhamberger span:nth-child(3) { transform: translate(4px, 0) rotate(-45deg) }
.cmshtml #mydrawer { position: fixed; top: 0; bottom: 0; left: 0; width: 100%; background-color: rgba(0, 0, 0, 0); opacity: 0; pointer-events: none; color: #fff; display: flex; justify-content: flex-end; transition: background-color 0.4s ease, opacity 0.4s ease; z-index: 999 }
.cmshtml #mydrawer.mydrawer-show { background-color: rgba(0, 0, 0, .72); opacity: 1; pointer-events: auto }
.cmshtml #mydrawerinner { width: 72%; background-color: #fff; transform: translateX(72%); transition: transform 0.6s ease }
.cmshtml #mydrawer.mydrawer-show #mydrawerinner { transform: translateX(0) }
.cmshtml .noscroll { overflow: hidden }
.cmshtml #drawernav { margin-top: 56px }
.cmshtml #drawernav > div { border-top: 1px solid #ddd }
.cmshtml #drawernav > div:last-of-type { border-bottom: 1px solid #ddd }
.cmshtml #drawernav a { display: block; padding: 8px 16px }
.cmshtml .mylayout01_corp {  }
.cmshtml .mylayout01_corp img { max-width: 100% }
.cmshtml .mylayout01_corpouter { margin-top: 30px }
.cmshtml .mylayout01_corpinner { text-align: center }
.cmshtml .mylayout01_corpbox {  }
.cmshtml .mylayout01_corpbox dl { font-family: 'Kiwi Maru', serif; line-height: 1.4 }
.cmshtml .mylayout01_corpbox dt { font-weight: 400 !important; font-size: 14px; letter-spacing: 1.6px }
.cmshtml .mylayout01_corpbox dd { font-weight: 400 !important; font-size: 24px; letter-spacing: 3px }
.cmshtml .mylayout01_corptext { font-size: 14px; margin: 15px 0 24px; letter-spacing: 1px}
.cmshtml .mylayout01_corp a { font-size: 14px }
.cmshtml .mylayout02_corp { padding: 40px 16px; background-color: #f7f7f7; text-align: center; line-height: 2 }
.cmshtml .mylayout02_corptitle { background: url(../img/contents_corp/back01.png) center bottom / 120px 2px no-repeat; padding-bottom: 24px; margin-bottom: 24px }
.cmshtml .mylayout02_corptitle img { max-width: 72% }
.cmshtml .mylayout03_corp {  }
.cmshtml .mylayout03_corp > div:nth-of-type(2) { margin-top: 24px } 
.cmshtml .mylayout03_corpimg { text-align: center; margin-bottom: 6px }
.cmshtml .mylayout03_corpimg img { max-width: 56% }
.cmshtml .mylayout03_corptext { margin-top: 18px; padding: 20px 25px; background-color: #f7f7f7; line-height: 1.8 }
.cmshtml .mylayout04_corp { display: flex; align-items: center; column-gap: 16px; padding-bottom: 12px; border-bottom: 2px dotted #b3b3b3; margin-bottom: 12px }
.cmshtml .mylayout04_corp > div:nth-of-type(1) { font-size: 14px; color: #fff; line-height: 1; padding: 5px 0 7px; width: 80px; text-align: center; background-color: #e50012; border-radius: 5px }
.cmshtml .mylayout04_corp > div:nth-of-type(2) { font-size: 20px; font-weight: 600; letter-spacing: 1px }
.cmshtml .mylayout04_corp strong { font-size: 25px; font-weight: 500 }
.cmshtml .mylayout04_corparrow { height: 56px; background: url(../img/contents_corp/image04.png) center center / 48px 18px no-repeat }
.cmshtml .mylayout05_corp { display: flex; justify-content : center; text-align: center; font-family: 'Noto Serif JP', sans-serif }
.cmshtml .mylayout05_corp > div { position: relative }
.cmshtml .mylayout05_corp dt { font-size: 22px; font-weight: 400 !important; letter-spacing: 1px; padding: 0 32px }
.cmshtml .mylayout05_corp dd { font-size: 15px; font-weight: 400 !important; padding: 0 32px }
.cmshtml .mylayout05_corp > div::before { display: block; position: absolute; top: -8px; left: 0; content: ''; width: 32px; height: 48px; border-top: 1px solid #000; border-left: 1px solid #000 }
.cmshtml .mylayout05_corp > div::after { display: block; position: absolute; right: 0; bottom: -8px; content: ''; width: 32px; height: 48px; border-right: 1px solid #000; border-bottom: 1px solid #000 }
}

@media (max-width: 560px) {
.cmshtml .mysection02banners > div { width: calc(50% - 8px) !important; overflow: hidden }
}

@media (min-width: 561px) and (max-width: 1079px) {
.cmshtml .mysection02banners > div { width: calc(33.333% - 10.7px) !important; overflow: hidden }
.cmshtml .mylayout05_corp br { display: none }
}

@media (min-width: 1080px) {
.cmsbody { font-weight: 330 }
.cmshtml :is(h1, .smallonly) { display: none }
.cmshtml #wrapper { position: relative; max-width: 1920px; margin: 0 auto }
.cmshtml #header_corp { max-width: 1920px; height: 66px; margin: 0 auto; display: flex; justify-content: space-between; padding: 20px 56px 0 24px; position: relative }
.cmshtml #headerlogo_corp img { max-width: 100% }
.cmshtml #globalnav_corp { display: flex; justify-content: center; column-gap: 50px; margin-top: 24px }
.cmshtml .globalnavparent_corp { height: 52px }
.cmshtml .globalnavparent_corp a { color: #fff; text-shadow: 0 0 4px #000; font-size: 17px; font-weight: 500; text-decoration: none; transition: .3s }
.cmshtml .globalnavparent_corp a:hover { opacity: .64 }
.cmshtml .globalnavchild_corp { opacity: 0; visibility: hidden; position: absolute; top: 80px; right: 0; left: 0; transition: .4s; background-color: #fff; transform: translateY(-16px); padding: 32px 24px 40px clamp(24px, calc(20.952vw + -202.29px), 200px) }
.cmshtml .globalnavinner_corp:hover .globalnavchild_corp { opacity: 1; visibility: visible; transform: translateY(8px) }
.cmshtml .globalnavchildinner_corp { max-width: 1328px; display: flex; flex-wrap: wrap; gap: 16px }
.cmshtml .globalnavchildinner_corp > div { width: calc(25% - 12px) }
.cmshtml .globalnavchild_corp a { display: block; text-decoration: none; color: rgb(var(--basecolor)); border-bottom: 1px solid rgb(var(--basecolor)); padding: 4px 4px 8px; transition: .3s; background: url(../img/corp/back01.png) 94% center no-repeat; font-size: clamp(15px, calc(0.119vw + 13.71px), 16px) }
.cmshtml .globalnavchild_corp a:hover { background-position: 98% center; opacity: .64 }
.cmshtml #mainvisual { position: relative; margin-top: -66px; z-index: -1 }
.cmshtml #mainvisual img { max-width: 100%; animation: myFadein 2s ease 0s }
.cmshtml #containerpagetitle_corp { position: relative; margin-top: -66px; z-index: -1 }
.cmshtml #pagetitleimg_corp img { width: 100%; height: 400px !important; object-fit: cover }
.cmshtml #pagetitleouter_corp { position: absolute; top: 0; right: 0; bottom: 0; left: 0; display: flex; justify-content: center; align-items: center }
.cmshtml #pagetitle_corp { color: #fff; text-align: center; text-shadow: 0 0 5px #000; line-height: 1.5 }
.cmshtml #pagetitle_corp dt { font-size: 50px; font-weight: 600 !important; letter-spacing: 6px }
.cmshtml #pagetitle_corp dd { font-size: 24px; font-weight: 400 !important; letter-spacing: 5px }
.cmshtml #maincontents_corp { margin: 72px 0 }
.cmshtml #mainvisualticker { display: flex; justify-content: space-between; align-items: center }
.cmshtml #mainvisualtickertitle { width: 239px }
.cmshtml .mynewarticles { width: calc(100% - 399px); padding-left: 206px }
.cmshtml #mainvisualtickertitlebtn { width: 160px }
.cmshtml #mainvisualtickertitlebtn a { display: inline-block; text-decoration: none; color: #000; font-weight: 600; font-size: 18px; background: url(../img/corp/back03.png) 90% center no-repeat; min-height: 30px; padding-right: 56px; transition: .3s }
.cmshtml #mainvisualtickertitlebtn a:hover { background-position: 98% center; opacity: .72 }
.cmshtml .containermysection01 { background: url(../img/corp/back04.jpg) center top / cover no-repeat; padding: clamp(80px, calc(3.571vw + 41.43px), 110px) 24px clamp(128px, calc(7.381vw + 48.29px), 190px) }
.cmshtml .mysection01 { max-width: 1230px; margin: 0 auto; display: flex; justify-content: space-between }
.cmshtml #wrapper .mysection01 > div:nth-of-type(1) { width: 34.146%; position: relative; z-index: 2; padding-top: 28px; overflow: visible !important }
.cmshtml .mysection01 > div:nth-of-type(2) { width: 60.975% }
.cmshtml #wrapper .mysection01titleen { font-size: clamp(104px, calc(2.857vw + 73.14px), 128px); font-weight: 600; color: transparent; -webkit-text-stroke: 1.5px rgb(var(--basecolor)); text-stroke: 1.5px rgb(var(--basecolor)); letter-spacing: -2px; line-height: 1 }
.cmshtml .mysection01title { margin-top: 24px }
.cmshtml .mysection01title h2 { font-size: clamp(28px, calc(0.952vw + 17.71px), 36px); font-weight: 330; letter-spacing: clamp(6px, calc(0.476vw + 0.86px), 10px); line-height: 1.3 }
.cmshtml .mysection01title i { font-size: clamp(48px, calc(1.071vw + 36.43px), 57px); font-style: normal; font-weight: 350; letter-spacing: clamp(3px, calc(0.238vw + 0.43px), 5px) }
.cmshtml .mysection01text { color: #4d4d4d; margin-top: clamp(24px, calc(0.952vw + 13.71px), 32px); line-height: 1.8 }
.cmshtml .mysection01img img { max-width: 100% }
.cmshtml .containermysection02 { margin-top: clamp(88px, calc(3.81vw + 46.86px), 120px) }
.cmshtml .containermysection03 { margin-top: clamp(104px, calc(6.667vw + 32px), 160px) }
.cmshtml .mysection02img img { max-width: 100% }
.cmshtml .mysection02outer { margin-top: -84px }
.cmshtml .mysection03outer { margin-top: -84px; display: flex; justify-content: flex-end }
.cmshtml .mysection02 { max-width: 1632px; padding: 70px clamp(48px, calc(5.714vw + -13.71px), 96px) 0; background-color: #fff; border-top-right-radius: 30px; position: relative; z-index: 2 }
.cmshtml .mysection03 { max-width: 1632px; padding: 70px clamp(48px, calc(5.714vw + -13.71px), 96px) 0; background-color: #fff; border-top-left-radius: 30px; position: relative; z-index: 2 }
.cmshtml .mysection02title { margin-top: -168px }
.cmshtml .mysection03title { margin-top: -168px; text-align: right }
.cmshtml :is(.mysection02title, .mysection03title) h2 { font-size: clamp(28px, calc(0.476vw + 22.86px), 32px); color: #fff; line-height: 1.2; letter-spacing: 10px; font-weight: 400; text-shadow: 0 0 5px #000 }
.cmshtml :is(.mysection02title, .mysection03title) h3 { font-size: clamp(72px, calc(3.214vw + 37.29px), 99px); color: rgb(var(--basecolor)); line-height: 1; font-weight: 700 }
.cmshtml .mysection02banners { display: flex; flex-wrap: wrap; gap: 30px 2.708%; margin-top: 32px }
.cmshtml .mysection02banners > div { width: 31.527%; overflow: hidden }
.cmshtml .mysection02banner { position: relative }
.cmshtml .mysection02banner img { max-width: 100%; transition: .4s }
.cmshtml .mysection02banner:hover img { transform: scale(1.15) }
.cmshtml .mysection02bannertitle { position: absolute; top: 0; right: 0; bottom: 0; left: 0; display: flex; align-items: flex-end; font-size: clamp(17px, calc(0.238vw + 14.43px), 19px); color: #fff; letter-spacing: clamp(1px, calc(0.238vw + -1.57px), 3px); background: url(../img/corp/back07.png) right bottom / clamp(32px, calc(2.143vw + 8.86px), 50px) clamp(32px, calc(2.143vw + 8.86px), 50px) no-repeat, url(../img/corp/back06.png) left 92% no-repeat, url(../img/corp/back05.png) center top / cover no-repeat; padding: 0 0 clamp(8px, calc(0.595vw + 1.57px), 13px) clamp(22px, calc(0.357vw + 18.14px), 25px) }
.cmshtml .mysection02banner a { position: absolute; top: 0; right: 0; bottom: 0; left: 0 }
.cmshtml .mysection02btn { margin-top: 48px; text-align: center }
.cmshtml .mysection02btn a { display: inline-block; text-decoration: none; color: #fff; padding: 11px 71px 11px 50px; border-radius: 80px; background: url(../img/corp/back08.png) 80% center no-repeat #000; transition: .3s; letter-spacing: 2px }
.cmshtml .mysection02btn a:hover { background-position: 84% center; opacity: .72 }
.cmshtml .containermysection04 { margin-top: 200px; padding: 70px 24px; background: url(../img/corp/back09.png) center bottom / 100% no-repeat #f7f7f7 }
.cmshtml .mysection04outer { position: relative; max-width: 1280px; margin: 0 auto }
.cmshtml .mysection04img { position: relative }
.cmshtml .mysection04img img { max-width: 100% }
.cmshtml .mysection04img::after { display: block; content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; border: 100px solid #f7f7f7; transition: .6s }
.cmshtml .mysection04img.is-show::after { border-width: 0 }
.cmshtml .mysection04inner { position: absolute; top: 0; right: 0; bottom: 0; left: 0; display: flex; align-items: center }
.cmshtml .mysection04 { width: 520px; border-left: 6px solid rgb(var(--basecolor)); background-color: #fff; padding: clamp(32px, calc(1.905vw + 11.43px), 48px) 24px clamp(24px, calc(1.905vw + 3.43px), 40px); text-align: center }
.cmshtml .mysection04 dt { color: rgb(var(--basecolor)); font-weight: 600 !important; letter-spacing: 1px }
.cmshtml .mysection04 dd { font-size: clamp(32px, calc(0.714vw + 24.29px), 38px); font-weight: 350 !important; letter-spacing: 6px; line-height: 1.4 }
.cmshtml .mysection04text { margin-top: 16px; font-weight: 330 }
.cmshtml .mysection04btn { margin-top: clamp(16px, calc(1.905vw + -4.57px), 32px) }
.cmshtml .mysection04btn a { display: inline-block; text-decoration: none; color: #fff; padding: 11px 71px 11px 50px; border-radius: 80px; background: url(../img/corp/back08.png) 80% center no-repeat rgb(var(--basecolor)); transition: .3s; letter-spacing: 2px }
.cmshtml .mysection04btn a:hover { background-position: 84% center; opacity: .72 }
.cmshtml #footer_corp { background: url(../img/corp/back10.jpg) center center / cover no-repeat; padding: 80px 24px }
.cmshtml .footerlogo_corp { text-align: center }
.cmshtml .footeraddress_corp { margin-top: 36px; text-align: center; color: #fff; font-size: 15px; letter-spacing: 1px }
.cmshtml .footeraddress_corp dt { font-weight: 330 !important }
.cmshtml .footeraddress_corp dd { font-weight: 330 !important; letter-spacing: 2px; margin-top: 8px }
.cmshtml .footeraddress_corp dd strong { font-size: 26px; font-weight: 330 !important }
.cmshtml .footeropeninfo_corp { text-align: center; color: #fff; margin-top: 16px }
.cmshtml .footeropeninfo_corp strong { display: inline-block; font-weight: 330; padding: 2px 44px; border: 1px solid #fff; font-size: 14px; letter-spacing: 2px }
.cmshtml .footersns_corp { display: flex; justify-content: center; column-gap: 8px; margin-top: 30px }
.cmshtml #footernav_corp { margin-top: 60px; display: flex; justify-content: center; align-items: flex-end; column-gap: 56px }
.cmshtml #footernav_corp a { color: #fff; font-size: 15px; letter-spacing: 3px }
.cmshtml .footernav_corp > div:not(:first-child) { margin-top: 6px }
.cmshtml #footernav_corp .footernavsub_corp a { font-size: 13px; letter-spacing: 2px }
.cmshtml .footernavsub_corp a::before { font-family: 'Font Awesome 6 Free'; content: '\f0da\00a0'; font-weight: bold; font-size: 11px }
.cmshtml .footernavbox_corp a { display: inline-block; background-color: #e50112; padding: 2px 20px 3px; font-size: 12px !important; letter-spacing: 1px !important; transition: .3s }
.cmshtml .footernavbox_corp a:hover { opacity: .72; text-decoration: none }
.cmshtml .footercopy_corp { font-size: 12px; color: #fff; text-align: center; background-color: #000; letter-spacing: 1px; padding: 10px }
.cmshtml .largetac { text-align: center }
.cmshtml #pt { position: fixed; bottom: 16px; right: 16px; display: none; opacity: 0; transition: opacity 0.5s ease; z-index: 998 }
.cmshtml #pagetop_corp a { display: inline-block; color: #fff; text-decoration: none; padding: 10px; background-color: #1d91ac; border-radius: 5px; font-size: 23px; line-height: 1; transition: .3s }
.cmshtml #pagetop_corp a:hover { background-color: #8bc53f }
.cmshtml :is(#mydrawerhambergerouter, #mydrawer) { display: none }
.cmshtml .mylayout01_corp { position: relative }
.cmshtml .mylayout01_corp img { max-width: 100% }
.cmshtml .mylayout01_corpouter { position: absolute; top: 0; right: 0; bottom: 0; left: 0; display: flex; justify-content : center; align-items: center }
.cmshtml .mylayout01_corpinner { width: 600px; background-color: rgba(255, 255, 255, .8); text-align: center; padding: 12px }
.cmshtml .mylayout01_corpbox { border: 1px solid #fff; padding: 35px 24px 28px }
.cmshtml .mylayout01_corpbox dl { font-family: 'Kiwi Maru', serif; line-height: 1.4 }
.cmshtml .mylayout01_corpbox dt { font-weight: 400 !important; font-size: 16px; letter-spacing: 1.6px }
.cmshtml .mylayout01_corpbox dd { font-weight: 400 !important; font-size: 30px; letter-spacing: 3px }
.cmshtml .mylayout01_corptext { font-size: 14px; margin: 15px 0 24px; letter-spacing: 2px}
.cmshtml .mylayout02_corp { padding: 70px 24px 60px; background-color: #f7f7f7; text-align: center; line-height: 2; letter-spacing: 1px }
.cmshtml .mylayout02_corptitle { background: url(../img/contents_corp/back01.png) center bottom / 120px 2px no-repeat; padding-bottom: 32px; margin-bottom: 28px }
.cmshtml .mylayout02_corptitle img { max-width: 100% }
.cmshtml .mylayout03_corp { display: flex; justify-content: space-between }
.cmshtml .mylayout03_corp > div { width: 47.5% } 
.cmshtml .mylayout03_corpimg { text-align: center; margin-bottom: 6px }
.cmshtml .mylayout03_corptext { margin-top: 18px; padding: 20px 25px; background-color: #f7f7f7; line-height: 1.8 }
.cmshtml .mylayout04_corp { display: flex; align-items: center; column-gap: 20px; padding-bottom: 18px; border-bottom: 3px dotted #b3b3b3; margin-bottom: 24px }
.cmshtml .mylayout04_corp > div:nth-of-type(1) { font-size: 14px; color: #fff; line-height: 1; padding: 5px 0 7px; width: 100px; text-align: center; background-color: #e50012; border-radius: 5px }
.cmshtml .mylayout04_corp > div:nth-of-type(2) { font-size: 23px; font-weight: 600; letter-spacing: 2px }
.cmshtml .mylayout04_corp strong { font-size: 30px; font-style: normal }
.cmshtml .mylayout04_corparrow { height: 72px; background: url(../img/contents_corp/image04.png) center center no-repeat }
.cmshtml .mylayout05_corp { display: flex; justify-content : center; text-align: center; font-family: 'Noto Serif JP', sans-serif }
.cmshtml .mylayout05_corp > div { position: relative }
.cmshtml .mylayout05_corp dt { font-size: 32px; font-weight: 400 !important; letter-spacing: 5px }
.cmshtml .mylayout05_corp dd { font-size: 17px; font-weight: 400 !important; letter-spacing: 1px }
.cmshtml .mylayout05_corp > div::before { display: block; position: absolute; top: -16px; left: -40px; content: ''; width: 48px; height: 68px; border-top: 1px solid #000; border-left: 1px solid #000 }
.cmshtml .mylayout05_corp > div::after { display: block; position: absolute; right: -40px; bottom: -16px; content: ''; width: 48px; height: 68px; border-right: 1px solid #000; border-bottom: 1px solid #000 }
.cmshtml .mylayout05_corp br { display: none }
}

/* パンくずリスト */
.cmshtml .rdBreadcrumb { }
.cmshtml .rdBreadcrumbItem { word-spacing: 4px; font-size: 88% }
.cmshtml .rdBreadcrumbItem:first-child::before { font-family: 'Font Awesome 6 Free'; content: '\f0da'; font-weight: 900 }
.cmshtml .rdBreadcrumbArrow { color: #999 }
.cmshtml .rdBreadcrumbLink { text-decoration: none; color: #333 }
.cmshtml .rdBreadcrumbLink:hover { color: #777 }

/* U01スライドショー */
.cmshtml .rdsp-buttons { display: none }

/* 共通装飾 */
/* 見出し */
.cmshtml .mytitle01 { text-align: center }
.cmshtml .mytitle01 dt { font-size: clamp(15px, calc(0.426vw + 13.4px), 18px); color: rgb(var(--basecolor)); font-weight: 600; letter-spacing: 1px }
.cmshtml .mytitle01 dd { font-size: clamp(24px, calc(1.135vw + 19.74px), 32px); letter-spacing: clamp(3px, calc(0.426vw + 1.4px), 6px); display: flex; justify-content: space-between; align-items: center; column-gap: clamp(16px, calc(1.986vw + 8.55px), 30px); line-height: 1; white-space: nowrap; margin-top: 3px }
.cmshtml .mytitle01 dd::before, .mytitle01 dd::after { display: block; content: ''; background-color: #333; height: 1px; width: 100% }
.cmshtml .mytitle02 dl { display: flex; gap: 4px 24px; align-items: flex-start; border-bottom: clamp(2px, calc(0.142vw + 1.47px), 3px) dotted #b3b3b3; padding-bottom: clamp(8px, calc(1.135vw + 3.74px), 16px) }
.cmshtml .mytitle02 dt { font-size: clamp(14px, calc(0.284vw + 12.94px), 16px); font-weight: 400 !important; color: #fff; background-color: rgb(var(--basecolor)); padding: 0 10px; margin-top: 5px }
.cmshtml .mytitle02 dd { font-size: clamp(18px, calc(0.709vw + 15.34px), 23px); font-weight: 400 !important }

.cmshtml .rdplanetitle h2 { font-size: clamp(17px, calc(0.426vw + 15.4px), 20px) !important; font-weight: 400 !important; color: #fff; padding: clamp(4px, calc(0.284vw + 2.94px), 6px) clamp(16px, calc(1.135vw + 11.74px), 24px); text-align: center; letter-spacing: clamp(2px, calc(0.426vw + 0.4px), 5px); background: url(../img/corp/back14.png) left top / clamp(16px, calc(1.135vw + 11.74px), 24px) no-repeat, url(../img/corp/back15.png) right bottom / clamp(16px, calc(1.135vw + 11.74px), 24px) no-repeat rgb(var(--basecolor)); }
.cmshtml .rdplanetitle h3 { font-size: clamp(18px, calc(0.567vw + 15.87px), 22px) !important; letter-spacing: clamp(1px, calc(0.284vw + -0.06px), 3px); font-weight: 400 !important; border-bottom: 2px dotted #b3b3b3; padding-bottom: clamp(4px, calc(0.567vw + 1.87px), 8px); display: flex; align-items: center; column-gap: 4px }
.cmshtml .rdplanetitle h3::before { content: '〇'; font-weight: 900; font-size: 16px; color: rgb(var(--basecolor)) }
.cmshtml .rdplanetitle h4 { font-size: clamp(16px, calc(0.284vw + 14.94px), 18px) !important; letter-spacing: 1px; font-weight: 400 !important; border-bottom: 2px dotted #b3b3b3; padding-bottom: clamp(4px, calc(0.567vw + 1.87px), 8px); display: flex; align-items: center; column-gap: 4px; color: rgb(var(--basecolor)) }
.cmshtml .rdplanetitle h4::before { content: '〇'; font-weight: 900; font-size: clamp(12px, calc(0.284vw + 10.94px), 14px) }
.cmshtml .rdplanetitle h5 { font-size: clamp(17px, calc(0.426vw + 15.4px), 20px) !important; font-weight: 500 !important; border-left: 5px solid rgb(var(--basecolor)); padding-left: 16px; line-height: 1.4 }
.cmshtml .rdplanetitle h6 { font-size: clamp(16px, calc(0.284vw + 14.94px), 18px) !important; font-weight: 500 !important; background-color: #eee; padding: 2px clamp(4px, calc(0.567vw + 1.87px), 8px); border: 1px solid #e8e8e8 }
@media (max-width: 1079px) {
.cmshtml .mytitle02 dl { flex-direction: column }
}

/* 単体エリア・横並びエリア */
@media (max-width: 1079px) {
.cmshtml .box01 { max-width: 100% !important; padding: 0 3% !important }
.cmshtml .flex50 { flex: 0 1 50% !important }
}

/* リンク */
.cmshtml :is(.link01, .link02, .link03, .link04) a { text-decoration: none; transition: .3s }
.cmshtml :is(.link01, .link03) a { display: inline-block }
.cmshtml :is(.link02, .link04) a { display: block; text-align: center }
.cmshtml :is(.link01, .link02) a { padding: 11px 71px 11px 50px; border-radius: 80px; background: url(../img/corp/back08.png) calc(100% - 40px) center no-repeat #000; letter-spacing: 2px; color: #fff }
.cmshtml :is(.link01, .link02) a:hover { opacity: .72; background-position: calc(100% - 32px) center }
.cmshtml :is(.link03, .link04) a { background-color: rgb(var(--basecolor)); color: #fff; padding: 6px 64px 6px 40px; font-weight: 500; border-radius: 80px; position: relative }
.cmshtml :is(.link03, .link04) a::after { display: block; position: absolute; top: 7px; right: 24px; font-family: 'Font Awesome 6 Free'; content: '\f105'; font-weight: bold }
.cmshtml :is(.link03, .link04) a:hover { opacity: .72 }

/* ボーダーありテーブル */
.cmshtml .tbl01 :is(th, td) { padding: 10px !important; border: 1px solid #ddd !important }
.cmshtml .tbl01 th { background-color: #f1f1f1 !important }
.cmshtml .tbl01 td { background-color: #fff; background-clip: padding-box }

/* force.cssの「PC/SPでは非表示」のviewportサイズを上書き */
@media (max-width: 1079px) {
.cmshtml [data-rdhide="sp"] { display: none !important }
}
@media (min-width: 576px) and (max-width: 1079px) {
.cmshtml [data-rdhide="pc"] { display: block !important }
}
@media (min-width: 1080px) {
.cmshtml [data-rdhide="pc"] { display: none !important }
}

/* ショッピングシステムのfooter装飾 */
.cmshtml main footer { background-color: initial; padding: 0 }

/* U01編集画面用 */
#editView .cmsbody { margin: 0; background-color: #fff; color: rgb(var(--textcolor)); line-height: 1.732; font-size: 16px; font-family: 'Noto Sans JP', sans-serif }
#editView :is(#globalnav, #footernav, #drawernav, #globalnav_corp) edit { padding: 8px }
#editView #pt { position: static; display: block; opacity: 1 }
#editView h5 edit { display: inline-block !important }
#editView #header_corp { height: auto }
#editView .globalnavchild_corp { opacity: 1; visibility: visible; position: static; transform: translateY(0) }
#editView .mysection04inner { position: static }
#editView #mydrawerhambergerouter { position: static; display: none }
#editView #mydrawer { position: static; opacity: 1; display: block }
#editView #pagetitleouter_corp { position: static }
#editView .mylayout01_corpouter { position: static }
#editView #containerpagetitle_corp { margin-top: 0 }

#editView #mainvisual { margin-top: 160px; z-index: 0 }
#editView .mysection02outer { margin-top: 0 }
#editView .mysection03outer { margin-top: 0 }
#editView .mysection02banners > div { overflow: visible }
#editView .mysection02banner:hover img { transform: scale(1) }
#editView .mysection02bannertitle { position: static; background-color: #999 }
#editView #containerpagetitle_corp { z-index: 0 }