/* ------------------------------------------
style.css用
------------------------------------------ */

body {
font: 16px 'Noto Sans JP', 'Lucida Grande', 'Hiragino Kaku Gothic ProN', sans-serif, Meiryo !important;
line-height: 180%;
}



.top_button a p{
width: 77%;
margin-top:7px;
margin-bottom:6px;
margin-left:20px;
padding-top:7px;
padding-bottom:7px;
border-right: 1px solid #006FCF;
color:#006FCF;
}

.top_button:hover a p {
	border-right: 1px solid #FFF;
    color: #FFF;
}


/*keyvisual*/

#ss1_top .keyvisual{
	margin-bottom: 0;
	background: #00A5FF;
    padding-bottom: 35px;
    margin-top: 130px;
}

.keyvisual-h1 {
    font-size: clamp(75px, 5vw, 83px);
    line-height: normal;
    font-weight: bold;
    color: #00A5FF;
    padding-top: 10px !important;
    padding-bottom: 20px;
    margin-left: 120px;
    line-height: 1.25;
}

.keyvisual-left_area:after{
	display:none;
}

.keyvisual-main{
	position: relative;
    height: 600px;
}

.keyvisual-main:after{
	position: absolute;
	content:'';
	background:#FFFFFF;
	border-radius: 0px 0px 0px 50px;
	width:calc(100% - 190px);
	height:100%;
	right:0;
    top: 0;
    z-index: 0;
}


.keyvisual-main-inner{
    display: flex;
    gap: 40px;
    padding-top: 25px;
	margin: 0 310px 0 200px;
    position: relative;
    z-index: 2;
    height: 600px;
	overflow: hidden;
}

.keyvisual-main-inner:before{
    position: absolute;
    content: '';
    background-image: url(https://www.dos-osaka.co.jp/ss1/img/top_main01.png);
    bottom: 0;
    left: -10px;
    width: 30%;
    height: auto;
    aspect-ratio: 546 / 393;
    background-size: contain;
    max-height: 300px;
    background-repeat: no-repeat;
}

.keyvisual-main-inner:after{
    position: absolute;
    content: '';
    background-image: url(https://www.dos-osaka.co.jp/ss1/img/top_main02.png);
    left: 274px;
    width: 32%;
    height: auto;
    aspect-ratio: 554 / 499;
    background-size: contain;
	bottom: -11%;
    z-index: -1;
    max-height: 400px;
    background-repeat: no-repeat;
}

.keyvisual-left_area{
	width: calc(100% - 600px) !important;
	margin: 0 !important;
}

.keyvisual-p{
    border-radius: 24px;
    background: #00A5FF;
    width: 300px;
    font-size: 35px;
    text-align: center;
    font-weight: bold;
    color: #FFF;
    display: flex;
    justify-content: center;
    line-height: normal;
    height: 75px;
    align-items: center;
    margin-left: 120px;
}


.keyvisual-small{
	font-size: 20px;
}


/*FVフォーム追加*/
#K3_headline h2{
	font-weight: bold;
	font-size: clamp(18px, 3.5vw, 21px);
    color: #42A3FC;
    text-align: center;
    padding-bottom: 2px;
}

.keyvisual-image-wide {
    background: #F5F8FA !important;
}
.keyvisual-right_area{
width: 560px;
border-radius: 25px;
padding: 25px;
background-color: #E0F0FD;
margin-bottom: 25px;
}

#K3_container{
background: #E0F0FD !important;
}

#K3_container hr{
    margin: 25px 0 0 0 !important;
}

.form-headline{
    margin: 0 !important;
}

.label-danger{
	background-color:#E13D58 !important;
}

.form-control {
    height: 35px!important;
    font-size: 14px!important;
	background: #cbe6f0;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
}

input[type="text"], textarea {
    border-radius: 6px;
	height: 35px;
    font-size: 14px;
}


input[type="submit"]:hover {
    background-color: #306ECC !important;
	border-color: #306ECC !important;
}
input[type="submit"] {
transition-duration: 0.25s;
    width: 200px;
    padding: 10px;
    text-align: center;
    border-radius: 25px;
    font-size: 18px;
	background-color: #F5E731;
    border-color: #F5E731;
    color: #306ECC;
    font-weight: bold;
}

/*フォーム追加*/
.form-group.control-group {
  display: flex;
	align-items: center;
	margin: auto 0 10px !important;
}

label.control-label{
	width: 30%;
    font-size: 14px;
}

.controls {
  width: 75%;
	position: relative;
}

.k3-customer-registration-form .control-group:nth-of-type(3){
	margin-bottom: 35px !important;
}

.k3-customer-registration-form .control-group:nth-of-type(3) .controls::after {
  display: block;
  content: '在宅勤務の方は連絡可能な携帯電話番号をご入力ください';
  position: absolute;
  width: 100%;
  height: auto;
  color: #555;
  bottom: -1.5em;
	font-size: 13px;
}


.privacy-policy-message{
	background: none !important;
    border: unset !important;
    box-shadow: none !important;
    padding: 10px 0 !important;
}

.help-block{
	display:none;
}

#K3_form_registered.jumbotron{
	padding: 15px 15px;
}

#K3_form_registered.jumbotron h2,
#K3_form_registered.jumbotron h3{
	font-size: 14px !important;
}

/* ------------------------------------------
（SS1　TOP）
------------------------------------------ */
/* 　SS1TOP　ITレビュー画像　 */

.itreview-area{
	margin: 35px 190px 0;
    width: fit-content;
    background: #FFF;
    border-radius: 20px;
    display: flex;
    padding: 20px 30px;
    gap: 40px;
    align-items: center;
}

.itreview-img-group{
    display: flex;
    align-items: center;
    gap: 15px;
	transition-duration: 0.3s;
}

.itreview-img-group:hover{
	opacity: 0.6;
}

.itreview-text{
	font-size: 12px;
    line-height: 1.5;
}

/* 　SS1TOP　フッター上部（SAMサービスとFAQ帯）ここから　 */
.c-cta_item {
position: relative;
}
.c-cta_item._demo::before {
background-image: url(../img/ss1footer_img_sam.webp);
}
.c-cta_item._seminar::before {
background-image: url(../img/ss1footer_img_faq.webp);
}
@media (min-width: 768px) {
  .c-cta_partsArea {
  display: flex;
  }
}

.c-cta_item_txt {
max-width: 365px;
height: 100px;
margin: 30px auto;
}

.c-cta_item::before {
content: "";
display: block;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-repeat: no-repeat;
background-position: 50% 50%;
background-size: cover;
}
.c-cta_item {
width: 50%;
height: 430px;
text-align: center
}
.cta_item_img {
position: relative;
z-index: 1;
padding: 60px 6.66667vw;
height: 100%;
text-decoration: none;
color: #fff;
justify-content: flex-start;
align-items: center;
}
.cta_item_img::before,
.cta_item_img::after {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
.c-cta_item_icon img {
max-width: 100%;
height: auto;
}

.banner-list04 .swiper-wrapper .entry-meta div {
display: block;
}

.banner-list04 .swiper-wrapper .entry-meta p {
font-size: clamp(12px, 3.8vw, 14px);
text-align: left;
color: #555;
}

.swiper-slide-a {
margin-bottom: 10px;
text-align: center;
color: #555;
}

.EventArea-entry-meta {
	min-height: 88px;
    height: auto;
}



.swiper-slide:hover {
	opacity: 0.6;
}

.swiper-slide {
	margin: 0 ;
	box-shadow: 3px 3px 6px #00000029;
	border: 1px solid #2A4D79;
	border-radius: 10px;
    background: #FFF;
	overflow: hidden;
    transition-duration: 0.3s;
	transition-property: unset !important;
}

.swiper-slide-bottom{
	background: #2A4D79;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    position: relative;
}

.swiper-slide-bottom:after{
    content: '';
    position: absolute;
    width: 12px;
    height: 4px;
    background-image: url(https://www.dos-osaka.co.jp/ss1/img/top_link01.png);
    right: 18px;
    background-size: cover;
}

.swiper-slide-bottom-text{
	color: #FFF;
    font-size: 14px;
    padding-right: 40px;
}

.caseArea-entry-meta {
display: block;
line-height: 1.5;
width: 100%;
}

.banner-list04 {
display: flex;
justify-content: space-around;
}

.banner-list04 .group {
margin: 20px 20px 15px;
}

.banner-list04 .entry-img {
transform-origin: left;
transition-property: color, transform;
transition-duration: 0.25s;
transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
}

.caseArea-photo{
	width: 100%;
    height: auto;
}

.banner-list04 .entry-img img{
height: auto;
border-radius: 10px;
}

.banner-list04 .entry-meta {
	padding-top: 10px;
}

.morelink {
position: absolute;
right: 26px;
bottom: 10px;
z-index: 2;
}

.swiper-wrapper {
padding-bottom: 40px;
height: auto !important;
align-items: stretch;
}

/* 　SS1TOP　ニュース部分 */

.newslist-index {
padding: 30px 0 20px;
margin-bottom:10px;
}

.newslist-index-li {
display: table;
width: 100%;
padding: 3px 0px;
border-top: 1px solid #999A9C;
margin-bottom: 0;
}

.newslist-index-li:last-of-type {
margin-bottom: 0;
border-bottom: 1px solid #999A9C;
}

.newslist-index-lower {
padding-bottom: 130px;
}

.entry-date {
display: table-cell;
width: calc(5em + 25px);
color:#999A9C;
font-size: 14px;
}

.newslist-index-li .entry-category {
display: table-cell;
width: 110px;
}

.label ,
.category {
position: relative;
width: 100%;
top: -1px;
}

.newslist-index-li .entry-cont {
display: table-cell;
padding-left: 20px;
line-height: 1.5;
font-weight: bold;
}

/* ＳＳ１ＴＯＰ　イベント部分 */
.EventArea {
    position: relative;
	height: 100%;
	width: 100%;
    padding-top: 0;
}

/* .EventArea::before {
	content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 50%;
            background: linear-gradient(206deg, #FFEAF5 0%, #B2E4FF 100%);
    z-index: -1;
        }

        .EventArea::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            width: 100%;
            height: 50%;
            background-color: #00A5FF;
    z-index: -1;
        }*/


.caseArea-inner ,
.functionArea-inner,
.reasonArea-inner,
.labArea-inner ,
.EventArea-inner {
padding: 100px 0;
}

.menuArea-main ,
.caseArea-main ,
.functionArea-main,
.reasonArea-main,
.cloudArea-main,
.labArea-main ,
.EventArea-main {
max-width: 1300px;
margin: 0 auto;
}


.EventArea-main{
	margin-top: 25px;
}

.EventArea-inner {
border-radius: 100px 0px 100px 0px;
background-color: #fff;
}

.caseArea .top_button ,
.labArea .top_button ,
.newsArea .top_button ,
.EventArea .top_button {
margin-right: 0;
margin-left: auto;
}

/*SCエリア*/
.scArea {
    position: relative;
    padding: 50px 0;
}

.scArea-inner:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(287deg, #FFEAF5 0%, #B2E4FF 100%);
    z-index: -1;
}

.scarea_box{
    background: #fff;
    width: 1000px;
    margin: 0 auto;
    border-radius: 20px;
    text-align: center;
}

.scarea_box a{
    display: block;
    padding: 20px 100px;
}

.scarea_headtext{
    color: #0C2468;
    font-weight: bold;
    font-size: 26px;
}

.scarea_box img{
    margin: 15px auto;
    height: auto;
}

.sc_button{
margin-right: 0;
    margin-left: auto;
    width: calc(7em + 30px);
    height: auto;
    border-bottom: solid 1px #0C2468;
    text-align: left;
position: relative;
}

.sc_button::after{
   content: '';
    background: url(https://www.dos-osaka.co.jp/ss1/img/ss1c_link_yaji.webp);
    width: 15px;
    height: 6px;
    position: absolute;
    right: 5px;
    top: 10px;
    transition-duration: 0.25s;
}

.scarea_box:hover .sc_button::after {
    right: 0px;
}

.scarea_link_text{
    color: #0C2468;
}


/* 　各帯のタイトル関連　 */
.caseArea .content-section-title ,
.caseArea .Area-txt {
position: relative;
z-index: 1;
}

.content-section-title {
width: 1080px;
height: 100px;
text-align: left!important;
}

.labArea .content-section-title-ja {
color: #fff;
background: transparent linear-gradient(91deg, #A1F9C7 0%, #09D6DE 100%) 0% 0% no-repeat padding-box;
}

.content-section-title-ja {
 padding: 25px 0 25px 300px ;
 font-size: clamp(18px,3.8vw,32px);
font-weight: bold;
color: #3C3C3C;
border-radius: 0px 30px 30px 0px;
background-color: #fff;
line-height: 1.5em;
}

.content-section-title-ja br{
	display:none;
}

/* 　黄色いボタンの記述（もっと見るなど）　 */
.top_button {
position: relative;
margin: auto;
width: 280px;
height: 55px;
border: 1px solid #006FCF;
transition-duration: 0.25s;
text-align: left;
background-color: #fff;
z-index: 1;
}
.top_button::after {
background: #006FCF;
position: absolute;
top: 0;
left: 0;
content: '';
width: 100%;
height: 100%;
transform: scale(0, 1);
transform-origin: left top;
transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
z-index: -1;
}
.top_button:hover a {
color: #fff;
}
.top_button:hover::after {
transform: scale(1, 1);
}
.top_button:hover a p::before {
background: #fff;
}
.top_button:hover a p::after {
border-top: 1px solid #fff;
}

.top_button a {
color: #006FCF;
}

.top_button a div {
margin: 21px;
}

.top_button a div::before{
top: 33%;
right: 25px;
}

.top_button a p::before {
top: 29%;
right: 25px;
}

.ss1top_No1 img {
max-width: 100%;
height: auto;
}

.top_button a p::before {
content: '';
position: absolute;
top: 50%;
right: 13px;
width: 6%;
height: 1px;
background: #006FCF;
transition: all .3s;
}
.top_button a p::after {
content: '';
position: absolute;
top: 43%;
right: 15px;
width: 7px;
height: 7px;
border-top: 1px solid #006FCF;
transform: rotate(45deg);
transition: all .3s;
}

/* 導入事例 */

.case-achieve-text-main{
	line-height: 1.5!important;
    margin-bottom: 10px;
}

.case-achieve-text{
	margin-bottom: 30px !important;
}

.caseArea-txt{
    text-align: center;
}

.caseArea {
position: relative;
background:#DEF0FE;
}

.caseArea:before {
content:'';
position:absolute;
background:#FFF;
height:100%;
width:calc(100% - 100px);
top:0;
right:0;
border-radius: 40px 0px 0px 40px;
}

.caseArea-inner{
    position: relative;
    z-index: 1;
}

.caseArea .entry-img {
    padding: 20px 20px 10px 20px;
}

.caseArea-logo {
position: absolute;
display: flex;
justify-content: center;
align-items: center;
left: -1px;
bottom: 0;
width: 51%;
height: 95px;
border-right: 17px solid #fff;
border-radius: 0px 10px 0px 0px;
background-color: #fff;
}

.caseArea-logo img {
max-width: 100%;
max-height: 90px;
height: auto;
width: auto;
object-fit: cover;
}

.ss1top-case-panel-a{
	display:contents;
}

.ss1top-case-panel,
.ss1top-case-category-list{
    box-shadow: 3px 3px 6px #2287BE4D;
    border: 1px solid #2A4D79;
    border-radius: 10px;
}

.ss1top-case{
    display: flex;
	gap:50px;
	margin-top:45px;
}

.ss1top-case-list-cover{
    width: calc(100% - 330px);
}

.ss1top-case-list{
    display: flex;
    gap: 20px;
    width: 100%;
}

.ss1top-case-category-list{
	width:280px;
	padding: 0 20px;
	background: #FFF;
}

.ss1top-case-category{
    height: calc(100% / 4);
    border-bottom: 1px solid;
    padding: 10px 0;
}

.ss1top-case-category:last-of-type{
    border-bottom: none;
}

.ss1top-case-category-a{
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    color: #2A4D79;
    font-size: 18px;
    justify-content: flex-start;
    position: relative;
    padding: 0 10px;
    z-index: 1;
}

.ss1top-case-category-a:hover{
    color: #FFF;
}

.ss1top-case-category-a:after{
	content:'';
	position: absolute;
	background-image:url(https://www.dos-osaka.co.jp/ss1/img/top_link03.png);
	width:30px;
	height:30px;
	right:10px;
}

.ss1top-case-category-a:hover:after{
	background-image:url(https://www.dos-osaka.co.jp/ss1/img/top_link03_h.png);
}

.ss1top-case-category-a:before{
    background: #2A4D79;
    position: absolute;
    top: 0;
    left: 0;
    content: '';
    width: 0;
    height: 100%;
  	-webkit-transition: .2s;
  	transition: .2s;
    z-index: -1;
    border-radius: 5px;
}

.ss1top-case-category-a:hover:before {
    width: 100%;
}

.ss1top-case-panel{
	width:calc( ( 100% - 40px ) / 3 );
    transition-duration: 0.3s;
	display: flex;
    flex-wrap: wrap;
    align-content: space-between;
    overflow: hidden;
    background: #FFF;
}

.ss1top-case-panel:hover{
    opacity: 0.6;
}

.ss1top-case-main{
	padding: 0 20px 0 20px;
}

.ss1top-case-name{
	font-size: 16px;
    font-weight: bold;
    line-height: 1.5;
}

.ss1top-case-title{
    line-height: 1.5;
    padding: 0.5em 0 1em;
	font-size: 14px;
}

.ss1top-case-category-group{
	display: flex;
	gap:5px;
	padding-bottom: 20px;
}

.ss1top-case-tag{
	font-size: 10px;
    background: #ECEEF3;
    border-radius: 5px;
    padding: 5px 10px;
}

.ss1top-case-panel-bottom{
    background: #2A4D79;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    position: relative;
    width: 100%;
}

.ss1top-case-panel-bottom:after{
	content: '';
    position: absolute;
    width: 12px;
    height: 4px;
    background-image: url(https://www.dos-osaka.co.jp/ss1/img/top_link01.png);
    right: 18px;
    background-size: cover;
}

.ss1top-case-panel-bottom-text{
	color: #FFF;
    font-size: 14px;
    padding-right: 40px;
}

/*Sクラ導線*/
.cloudArea {
    background: #FFF;
    position: relative;
}

.cloudArea:before {
    content: '';
    background: #DBF1FF;
    position: absolute;
    height: 100%;
    width: calc(100% - 100px);
    top: 0;
    left: 0;
    border-radius: 0px 40px 0px 0px;
}

.cloudArea-inner {
    position: relative;
    z-index: 1;
    padding: 100px 0 20px;
}

.compareArea {
    background: linear-gradient(90deg, #54D6FF 0%, #1C86FF 100%) left / 50% 100% no-repeat, linear-gradient(90deg, #B2E4FF 0%, #FFEAF5 100%) right / 50% 100% no-repeat;
    position: relative;
    z-index: 1;
}

.compare-group {
    max-width: 1300px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    gap: 160px;
    padding: 80px 0;
}

.compare-panel{
	background: #FFF;
    border-radius: 20px;
    width: calc((100% - 160px) / 2);
    text-align: center;
}

.compare-panel-link{
	height:100%;
    padding: 30px 0 45px;
    display: block;
  	-webkit-transition: .2s;
  	transition: .2s;
}

.compare-panel-link:hover{
	opacity: 0.6;
}

.compare-panel-text {
    color: #00A5FF;
    font-weight: bold;
    margin-top: 30px;
}

.compare-panel-imgArea{
	height: 68px;
    display: flex;
    justify-content: center;
    align-items: flex-end;
}

.barbutton{
	position: absolute;
    bottom: -40px;
    z-index: 1;
    background: #00A5FF;
    width: 650px;
    height: 80px;
    right: 0;
    border-radius: 20px 0 0 20px;
    padding-left: 120px;
    text-align: right;
    display: flex;
    align-items: center;
	justify-content: flex-start;
	overflow: hidden;
}

.barbutton:after{
	content:'';
	position: absolute;
  	width: 0%;
  	height: 100%;
    border-radius: 20px 0 0 20px;
    background:#01297B;
  	top: 0;
  	left: 0;
  	z-index: -1;
  	-webkit-transition: .2s;
  	transition: .2s;
}

.barbutton:hover:after{
  	width: 100%;
}

.barbutton-text{
    color: #FFF;
	position: relative;
}

.barbutton-text:after{
	content:'';
    position: absolute;
	background-image:url(https://www.dos-osaka.co.jp/ss1/img/top_link01.png);
    width: 15px;
    height: 5px;
    right: -1.5em;
    top: 0.65em;
    background-size: cover;
}

/* ラボ */
.labArea {
position: relative;
height: 100%;
width: 100%;
        margin-top: 200px;
background: #EBEEF3;/* Old browsers */
background: -moz-linear-gradient(top, rgba(235,238,243,1) 0%, rgba(235,238,243,1) 51%, rgba(255,255,255,1) 51%, rgba(255,255,255,1) 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top, rgba(235,238,243,1) 0%,rgba(235,238,243,1) 51%,rgba(255,255,255,1) 51%,rgba(255,255,255,1) 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom, rgba(235,238,243,1) 0%,rgba(235,238,243,1) 50.4%,rgba(255,255,255,1) 50.4%,rgba(255,255,255,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
}

.labArea-inner {
position: relative;
z-index: 1;
}

/* 敬礼部分などの帯 */
section.keyvisual-image-call {
padding-bottom: 100px;
}

.entrylist04-index {
padding: 0;
}

.entrylist04-index .group {
margin-top: 40px;
padding: 0px;
}

.entry-point {
display: table-cell;
vertical-align: middle;
padding: 2px 30px;
border-radius: 5px;
background-color: #00A5FF;
color: #fff;
}

.entrylist04-index .group .clear .entry-meta {
width: 52%;
float: left;
margin-top: 0;
}

.entrylist04-index .group .clear .entry-meta + img {
width: 56%;
}

.entrylist04-index .group .clear:nth-of-type(2n) .entry-meta {
width: 45%;
float: right;
}

.entrylist04-2nd .entry-meta {
margin-top: 0%;
}

.entrylist04-3rd .entry-meta {
margin-top: 0%;
}

.entrylist04-4th .entry-meta {
margin-top: 0%;
}

.entrylist04-index .group .clear .entry-img{
float: left;
width: 55%;
box-shadow: 5px 5px 20px 0 rgba(85, 85, 85, 0.5);
border-radius: 10px;
text-align: center;
}

.entry-video video {
display: block;
}

.entrylist04-index .group .clear .entry-video {
padding: 0;
}

.video-ss1top {
object-fit: cover;
width: 100%;
max-width: 680px;
}

.entrylist04-index .group .clear:nth-of-type(2n+1) .video-ss1top {
border: solid 1px #d9d9d9;
}

.entrylist04-index .group .clear .entry-img img {
width: 90%;
margin: 3% 0;
}

.entry-title {
margin: 10px 0 15px 0;
padding-bottom: 0px;
 font-size: 27.5px;
font-weight: bold;
border-bottom: solid 1px #e9e9e9;
line-height: 38px;
border-bottom: 0;
}

.entry-title-h3{
line-height: 1.85;
}

.entrylist04-index ul li {
width: 100%;
height: 100%;
margin-top: 0;
margin-bottom: 70px;
padding-top: 50px;
padding-bottom: 70px;
}

.entrylist04-first {
margin-top: 0px;
padding-top: 0px;
}

.entry-text {
line-height: 1.5;
}

/*まるごとサポート*/
.menuArea{
background: #FFF;
position: relative;
}

.menuArea:before{
content:'';
background: #DBF1FF;
position:absolute;
height:100%;
width:calc(100% - 100px);
top:0;
left:0;
border-radius: 0px 0px 40px 0px;
}

.menuArea-inner {
	padding: 100px 0;
    position: relative;
    z-index: 1;
}

.top-white-box{
    border-radius: 30px;
    background: #FFF;
    width: 1300px;
    text-align: center;
    padding: 50px;
}

.top_button-group{
	display: flex;
    justify-content: center;
    gap: 60px;
}

.top_button-group .top_button{
	margin: unset;
}

/*選ばれる理由*/

.reasonArea{
    position: relative;
    background: #DEF0FE;
}

.reasonArea:before {
    content: '';
    position: absolute;
    background: #FFF;
    height: 100%;
    width: calc(100% - 100px);
    top: 0;
    right: 0;
    border-radius: 40px 0px 0px 40px;
}

.reasonArea-inner {
    position: relative;
    z-index: 1;
}

.newsArea .content-section-title-ja,
.reasonArea .content-section-title-ja{
	background-color: unset;
}

.reasonArea-main{
    display: flex;
    gap: 20px;
}

.reason-group{
    width: calc((100% - 40px) / 3);
}

.reason-title{
    text-align: center;
    color: #00A5FF;
    font-weight: bold;
    font-size: 22px;
    letter-spacing: 2.2px;
    width: fit-content;
    margin: 0 auto 10px auto;
	position: relative;
}

.reason-title:before,
.reason-title:after {
    content: "";
    position: absolute;
    background-color: #00A5FF;
    height: 3px;
    width: 24px;
    top: 20px;
}
.reason-title:before {
    left: -1.25em;
    transform: rotate(60deg);
}
.reason-title:after {
	right:-1.25em;
    transform: rotate(-60deg); 
}

.reason-panel{
	display: block;
    box-shadow: 3px 3px 6px #2287BE4D;
    border: 1px solid #2A4D79;
    border-radius: 10px;
    overflow: hidden;
    transition-duration: 0.3s;
}

.reason-panel:hover{
    opacity: 0.6;
}

.reason-panel-main{
	display: flex;
    gap: 15px;
    padding: 15px 15px 15px 20px;
    align-items: center;
}

.reason-panel-img{
	max-width: 130px;
    max-height: 90px;
    height: auto;
    width: auto;
}

.reason-panel-text{
    font-weight: bold;
    font-size: 18px;
    line-height: 1.5;
}

.reason-panel-bottom{
    background: #2A4D79;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    position: relative;
}

.reason-panel-bottom:after{
	content:'';
    position: absolute;
	width: 12px;
	height: 4px;
	background-image:url(https://www.dos-osaka.co.jp/ss1/img/top_link01.png);
	right:18px;
	background-size: cover;
}

.reason-panel-bottom-text{
    color: #FFF;
    font-size: 14px;
    padding-right: 40px;
}

/*特長*/
.featureArea{
background: #fff;
position: relative;
z-index: -2;
}

.featureArea:before{
content: '';
width: 75%;
height: 100%;
background: #DBF0FF;
position: absolute;
z-index: -1;
border-radius: 0px 100px 0px 0px;
}

.featureArea:after{
content: '';
background: url(../img/featureArea_act.webp);
width: 345px;
height: 273px;
display: inline-block;
position: absolute;
bottom: 0;
left: 3%;
background-size: contain;
background-repeat: no-repeat;
}

.featureArea-inner{
padding-top: 100px;
}

.featureArea .entrylist04-index{
max-width: 1300px;
margin: 0 auto;
padding-bottom: 50px !important;
}

.entrylist04-index .group .clear .entry-img{
background: #fff;
border: 30px solid #fff;
border-radius: 20px;
box-shadow: none;
}

.entry-title-h3{
font-size: 24px;
line-height: 1.5em;
}

.entry-point{
color: #006FCF;
font-size: 12px;
padding: 0;
border-radius: 0;
background: none;
position: relative;
}

.entry-point:after{
content: '';
display: block;
background: #006FCF;
width: 70px;
height: 1px;
position: absolute;
top: 45%;
right: -6.5em;
}

.entrylist04-index .entry-text p{
line-height: 1.5 !important;
font-size: 14px;
}

.entrylist04-index .group .clear .entry-meta{
width: 43%;
float: right;
margin-top: 0;
max-width: 520px;
padding-top:50px;
}

.entrylist04-index .group .clear .entry-img{
float: right;
}

.entrylist04-index .group .clear:nth-of-type(2n) .entry-meta{
float: left;
}

.entrylist04-index .group .clear:nth-of-type(2n+1) .entry-img{
float: left;
}

.entrylist04-index .group .clear .entry-meta{
float: right;
}

.entrylist04-index ul li{
margin-bottom: 50px;
padding:0;
}

/*ニュース 最新情報*/
.newsArea{
position: relative;
	background:#ECEEF3;
}


/*.keyvisual-image-call{
background:#fff;
}*/

.newsArea-main {
max-width:1300px;
margin:0 auto;
}

.newslist-index,
.newslist-index a{
color:#5A5A5A
}

.newslist-index {
max-width:1300px;
margin:0 auto;
}

.newslist-index-li a{
display: block;
width: 100%;
padding: 20px 25% 20px 10px;
position:relative;
}

.newslist-index-li a:hover{
    background: #FFF;
}

.newslist-index-li a:after{
content: '';
background: url(../img/more_red.webp);
width: 30px;
height: 30px;
display: inline-block;
position: absolute;
top: calc(50% - 15px);
right: 20px;
background-size: contain;
}

section.keyvisual-image-call{
padding: 100px 0;
}

.award{
background: #A674B0;
}

.events{
background: #7dc800;
}

.notices {
background: #ff889c;
}

.open {
background: #ffb900;
}

.category{
border-radius: 5px;
text-align: center;
color:#fff;
line-height: 2em;
font-size:14px;
}

.entry-cont{
font-size:16px;
}

/*課題解決*/
.functionArea{
	background: #FFF;
    position: relative;
}

.functionArea:before {
    content: '';
    background: #DBF1FF;
    position: absolute;
    height: 100%;
    width: calc(100% - 100px);
    top: 0;
    left: 0;
	border-radius: 0px 40px 40px 0px;
}

.functionArea-inner{
    position: relative;
    z-index: 1;
}

.function-group-box{
	box-shadow: 0px 3px 6px #00000029;
    border-radius: 25px;
    background: #FFF;
    padding: 30px 0;
    text-align: center;
}

.function-group-box-title {
    font-size: 20px;
    font-weight: bold;
    color: #3C3C3C;
	margin-bottom: 15px;
}

.function-group-box-group{
	display: flex;
    gap: 20px;
}

.functionArea-main > .function-group-box-group:nth-child(2) {
    margin: 20px 0;
}

.function-group-box-group .function-group-box{
    width: calc((100% - 20px) / 2);
}

.function-group{
    display: flex;
    gap: 20px;
	flex-wrap: wrap;
	width: calc((260px * 4) + 60px);
    margin: auto;
}

.function-group-box-group .function-group{
	width: calc((260px * 2) + 20px);
}

.function-panel{
	width: 260px;
    color: #FFF;
    height: 60px;
    display: flex;
    align-items: center;
    padding: 0 20px;
    border-radius: 10px;
    text-align: left;
	position: relative;
	transition-duration: 0.3s;
	box-shadow: 0px 3px 6px #00000029;
}

.function-panel:hover{
	opacity: 0.6;
    color: #FFF;
}

.function-panel:before{
	content:'';
    position: absolute;
	width:40px;
	height:100%;
	border-radius: 0px 10px 10px 0px;
	right:0;
}

.function-panel:after{
	content:'';
    position: absolute;
	right:12px;
	background-image:url(https://www.dos-osaka.co.jp/ss1/img/top_link01.png);
	width:12px;
	height:4px;
    background-size: cover;
}

.function-lightblue{
    background: #01BEFF;
}

.function-lightblue:before{
	background:#0185B2;
}

.function-blue{
    background: #00A5FF;
}

.function-blue:before{
	background:#0073B2;
}

.function-red{
    background: #F56F71;
}

.function-red:before{
	background:#AB4D4F;
}

.function-yellow{
    background: #F8BB2B;
}

.function-yellow:before{
	background:#AD831E;
}

.function-green{
    background: #82C722;
}

.function-green:before{
	background:#5B8B18;
}

.function-purple{
    background: #A475AF;
}

.function-purple:before{
	background:#72527A;
}

.function-black{
    background: #555555;
}

.function-black:before{
	background:#3B3B3B;
}


/*レスポンシブ用*/

@media(min-width:2200px){
.keyvisual-right_area,
.keyvisual-left_area{
	width: 40% !important;
}

.keyvisual-h1,
.keyvisual-p{
    margin-left: 0px;
}

.keyvisual-main-inner{
	justify-content: center;
}

}


@media (max-width: 1890px) {

.keyvisual-h1 {
    font-size: clamp(75px, 4vw, 83px);
}

.keyvisual-main-inner:before{
	width: 35%;
}

.keyvisual-main-inner:after{
	width: 35%;
}

}



@media(max-width:1830px){

    .keyvisual-h1 {
        font-size: clamp(75px, 5vw, 83px);
    }

.keyvisual-main-inner{
    margin: 0 260px 0 100px;
}

.keyvisual-main:after{
    width: calc(100% - 100px);
}

.itreview-area{
	margin: 35px 100px 0;
}

}

@media(max-width:1800px){

.caseArea:before{
	display:block !important;
}


}

@media(max-width:1740px){

    .keyvisual-h1 {
        font-size: clamp(75px, 4.5vw, 83px);
    }

}


@media (max-width: 1700px) {

#ss1_top .keyvisual{
	margin-top: 112px;
}

.keyvisual-main-inner:before{
    width: 44%;
}

.keyvisual-main-inner:after{
    width: 44%;
}

.keyvisual-left_area{
    width: fit-content !important;
}

	.keyvisual-h1{
        font-size: clamp(75px, 5vw, 86px) !important;
	}

    .keyvisual-main-inner:before {
        width: 35%;
	}

	.keyvisual-main-inner:after{
		width: 35%;
	bottom: -9%;
	}

	.keyvisual-main-inner{
		margin: 0 100px 0 100px;
    justify-content: center;
	}

}

@media (max-width: 1600px) {

#K3_headline h2 {
	margin: 5px 0 0 0 !important;
}

.keyvisual-main,
.keyvisual-main-inner{
	height: 580px;
}


.keyvisual-main-inner{
	padding-top: 20px;
}

    .keyvisual-right_area {
        width: 540px !important;
	padding: 15px 25px;
    }

	.keyvisual-left_area {
		width: calc(100% - 580px) !important;
	}

    .keyvisual-h1 {
        font-size: clamp(70px, 4vw, 86px) !important;
	}

	.keyvisual-p,
	.keyvisual-h1{
		margin-left: 80px;	
	}

	.menuArea-main,
	.functionArea-main,
	.reasonArea-main,
	.cloudArea-main{
		padding: 0 100px;
	}

	.top-white-box{
	    width: 1000px;
    	margin: auto;
	}

.EventArea-entry-meta{
    min-height: 113px;
}

.function-group{
    width: calc((220px * 4) + 60px);
}

.function-panel{
    width: 220px;
}

.function-group-box-group .function-group{
    width: calc((220px * 2) + 20px);
}

.reason-panel-text{
    font-size: 16px;
}

}

@media (max-width: 1420px) {

.keyvisual-h1{
	font-size: clamp(55px, 4.5vw, 70px) !important;
}

}

@media (max-width: 1400px) {

.keyvisual-main-inner:after{
    left: 20%;
}

    .top-white-box {
        width: 800px;
        margin: auto;
    }

	.ss1top-case{
 	   gap: 20px;
	}

	.ss1top-case-category-list {
    	width: 230px;
	}

	.ss1top-case-list-covert{
		width: calc(100% - 250px);
	}

    .function-group {
        width: calc((290px * 2) + 20px);
		justify-content: center;
    }

    .function-group-box-group .function-group {
        width: 100%;
	}

    .function-panel {
        width: 290px;
    }

	.barbutton {
   		width: 450px;
		padding-left: 100px;
	}

	.compare-group {
    	max-width: 1000px;
	}

	.menuArea:before,
	.caseArea:before,
	.reasonArea:before,
	.functionArea:before,
	.cloudArea:before{
	    width: calc(100% - 30px);
	}

}

@media(max-width:1340px){
    .keyvisual-h1 {
        font-size: clamp(55px, 4vw, 60px) !important;
    }

}

@media(max-width:1300px){

#ss1_top .keyvisual{
	margin-top: 62px;
}

.keyvisual-right_area{
	display:none;
}

.keyvisual-main,
.keyvisual-main-inner {
        height: 350px;
    }

.keyvisual-main-inner:before{
	left: unset;
	right: 60px;
}

.keyvisual-main-inner:after{
	left: unset;
	right: -43px;
 	bottom: 30px;
}

    .keyvisual-h1 {
        font-size: clamp(65px, 5vw, 86px) !important;
}

.keyvisual-left_area {
	width:100% !important;
}
.itreview-area{
    gap: 15px;
    flex-direction: column;
}

.itreview-img-group{
    justify-content: center;
        display: grid;
}

.EventArea-entry-meta{
	min-height: 120px;
}

.reasonArea-main{
    align-items: stretch;
}

.reason-panel{
    height: calc(100% - 50px);
}

.reason-panel-main{
	height: calc(100% - 40px);
}

}


@media(max-width:1200px){
.keyvisual-h1{
        font-size: clamp(55px, 5vw, 86px) !important;
}

.scarea_box{
    width: 800px;
}

.caseArea-logo {
height: 65px;
}

.ss1top-case{
    flex-direction: column;
        gap: 30px;
}

.ss1top-case-list-cover{
        width:100%;
}

.ss1top-case-category-list{
	flex-wrap: wrap;
	width: 400px;
	margin: auto;
	display: flex;
    padding: 10px;
}

.ss1top-case-category{
	width: calc(100% / 2);
    height: 70px;
}

.ss1top-case-category-a:after{
    width: 20px;
    height: 20px;
	background-size: contain;
    background-repeat: no-repeat;
}

.ss1top-case-category{
    border-bottom: none;
}

.ss1top-case-category:nth-child(1),
.ss1top-case-category:nth-child(3){
	padding: 0 10px 0 0;
    border-right: 1px solid #2A4D79;
}

.ss1top-case-category:nth-child(2),
.ss1top-case-category:nth-child(4){
	padding: 0 0 0 10px;
}


.ss1top-case-category:nth-child(1) .ss1top-case-category-a,
.ss1top-case-category:nth-child(2) .ss1top-case-category-a{
	border-bottom: 1px solid #2A4D79;
}

.ss1top-case-category-a:before{
    top: 3%;
    height: 94%;
}

.compare-group{
	max-width: 800px;
}

.compare-panel-link{
    padding: 30px 20px;
}

.top-white-box{
	width: 100%;
}

.top_button-group{
	gap: 10px;
    flex-wrap: wrap;
    flex-direction: column;
    align-items: center;
    margin-top: 20px;
}

}

@media (max-width: 1130px) {

.keyvisual-main{
    overflow: hidden;
}

.keyvisual-main-inner {
    overflow: unset;
}
}

@media (max-width: 1100px) {

.function-group{
	flex-direction: unset !important;
	flex-wrap: wrap;
}

.reasonArea-main{
    gap: 20px;
    flex-wrap: wrap;
    flex-direction: column;
    align-items: center;
}

.reason-group{
    width: 100%;
    max-width: 450px;
}

}

@media (max-width: 1000px) {

.keyvisual-left_area {
        width: 100% !important;
}

.content-section-title-ja br{
	display:block;
}

.functionArea-inner{
	padding: 50px 0;
}


}

@media (max-width: 900px) {

.keyvisual-p, .keyvisual-h1 {
        margin-left: 40px;
    }

    .keyvisual-h1 {
        font-size: clamp(45px, 5vw, 86px) !important;
    }

.keyvisual-p{
	border-radius: 15px;
	width: 220px;
    font-size: 25px;
    height: 50px;
}

.compareArea{
    background: linear-gradient(90deg, #54D6FF 0%, #1C86FF 100%) top / 100% 50% no-repeat, linear-gradient(90deg, #B2E4FF 0%, #FFEAF5 100%) bottom / 100% 50% no-repeat;
    margin-right: 30px;
}

.compare-group{
    gap: 80px;
	padding: 45px 0;
	flex-direction: column;
    align-items: center;
	margin: 0 30px 0 60px;
}

.compare-panel{
    width: 100%;
}

.barbutton{
	right: -30px;
    bottom: -50px;
}

}

@media (max-width: 800px) {

body.rene {
	font-size: 14px !important;
}

	.function-group-box,
	.function-group-box-group .function-group-box{
   		width: 70%;
    	margin: auto;
    	padding: 30px;
	}

 	.function-group,
    .function-group-box-group .function-group {
        width: 100%;
    }

	.function-group-box-group{
	    flex-direction: column;
	}

    .function-panel {
        width: 100%;
        height: 40px;
        font-size: 14px;
        border-radius: 5px;
    }

.function-panel:before{
    border-radius: 0px 5px 5px 0px;
}

	.function-panel br{
		display: none;
	}

	.function-group-box-title {
    	font-size: clamp(14px, 3vw, 18px);
	}

	.ss1top-case-list-cover{
		overflow: scroll;
  		/*IE(Internet Explorer)・Microsoft Edgeへの対応*/
  			-ms-overflow-style: none;
  		/*Firefoxへの対応*/
  			scrollbar-width: none;
		}

 		/*Google Chrome、Safariへの対応*/
		.ss1top-case-list-cover:-webkit-scrollbar{
  			display: none;
		}

	.ss1top-case-list{
		width: fit-content;
        padding-bottom: 10px;
		padding-right: 30px;
	}


	.ss1top-case-panel{
    	width: 270px;
	}



}

@media (max-width: 700px) {

.crown_area {
    width: 100%;
}

}

@media (max-width: 600px) {
    .menuArea-main,
	.functionArea-main,
	.reasonArea-main,
	.cloudArea-main {
        padding: 0 30px;
    }

.keyvisual-main-inner{
    margin: 0 15px 0 0px;
}

.keyvisual-main,
.keyvisual-main-inner{
	height: 450px;
}

.keyvisual-main:after {
        width: calc(100% - 15px);
        border-radius: 0px 0px 0px 20px;
}

.keyvisual-p,
.keyvisual-h1 {
        margin-left: 30px;
    }

.keyvisual-p{
    width: 160px;
    font-size: 18px;
    border-radius: 12px;
    height: 40px;
}

.keyvisual-h1{
	font-size: clamp(40px, 10vw, 60px) !important;
	line-height: 1.25 !important;
}

.keyvisual-small{
	font-size: 16px;
}

.keyvisual-main-inner:after{
	right: 100px;
        bottom: -13px;
        width: 52%;
}

.keyvisual-main-inner:before{
        width: 53%;
        left: 0;
        right: unset;
		bottom: -1px;
}

.itreview-area{
	border-radius: 10px;
    width: calc(100% - 30px);
    margin: 25px 15px 10px;
}

.itreview-text{
    font-size: 8px;
}

.ss1top-case-category-list{
	width: calc(100% - 60px);
}

    .menuArea:before,
	.caseArea:before,
	.reasonArea:before,
	.functionArea:before,
	.cloudArea:before {
        width: calc(100% - 15px);
    }

.menuArea-inner,
.caseArea-inner,
.functionArea-inner,
.reasonArea-inner,
.labArea-inner,
.EventArea-inner
{
	padding:50px 0 !important;
}

.cloudArea-inner{
    padding: 50px 0 20px;
}

.functionArea{
	padding:0 !important;
}

.ss1top-case-list-cover{
	padding-left: 30px;
}

.compareArea{
	margin-right: 15px;
}

.barbutton {
	width: calc(100% - 135px);
	height: 60px;
	bottom: -45px;
	right: -15px;
	padding-left: 40px;
	border-radius: 10px 0px 0px 10px;
}

.barbutton-text{
    font-size: 14px;
}

.barbutton:after{
	border-radius: 10px 0px 0px 10px;
}

.menuArea:before{
    border-radius: 0px 0px 20px 0px;
}

.caseArea:before,
.reasonArea:before{
    border-radius: 20px 0px 0px 20px;
}

.functionArea:before{
	border-radius: 0px 20px 20px 0px;
}

.cloudArea{
    border-radius: 0px 20px 0px 0px;
}

.top-white-box{
    padding: 10px 15px 30px;
    border-radius: 10px;
}

.top_button-group{
	margin-top: 25px;
}

.function-group-box,
.function-group-box-group .function-group-box{
	width: 100%;
	border-radius: 10px;
}

.function-group{
    gap: 5px;
}

.function-panel:before{
    width: 30px;
}

.function-panel:after {
    right: 9px;
}

.ss1top-case-category{
	height: 60px;
}

.ss1top-case-category-a{
    font-size: 14px;
}

.ss1top-case-category-a:after {
	width: 15px;
	height: 15px
}

.caseArea .entry-img{
    padding: 10px 10px 0;
}

.ss1top-case-main{
	padding: 10px 10px 0;
}

.ss1top-case-name,
.ss1top-case-title,
.ss1top-case-panel-bottom-text{
    font-size: 12px;
}

.ss1top-case-tag{
	padding: 2px 10px;
}

.ss1top-case-panel-bottom{
    height: 30px;
}

.Area-txt{
	padding: 0 !important;
}

.case-achieve-text,
.caseArea-txt{
    padding: 0 30px !important;
}


.reason-panel-img{
    width: 34%;
}

    .reason-panel-text {
        font-size: 14px;
    }

.reason-panel-bottom{
    height: 30px;
}


.reason-panel-bottom-text{
    font-size: 12px;

}

.reason-title:before, .reason-title:after{
        width: 18px;
        top: 17px;
}

.reason-title{
	font-size: 18px;
}

.newsArea{
	border-radius: 0 !important;
}

.newsArea-main{
    padding: 0 30px !important;
}

.compare-panel{
	box-shadow: 0px 3px 6px #00000029;
	border-radius: 10px;
}

.compare-panel-link{
	padding: 20px;
}

.compare-panel-text {
	font-size:14px;
    margin-top: 20px;
}

.compare-panel-imgArea{
    height: 40px;
}

.compare-panel:nth-child(1) .compare-panel-imgArea{
    height: 30px;
}

.compare-panel-img{
	max-height: 100%;
	width:auto;
}

.EventArea-inner{
    padding-top: 80px !important;
}

.newslist-index{
    padding-top: 0 !important;
}


.function-group-box,
.function-group-box-group .function-group-box{
        padding: 30px 20px;
}

}


@media (max-width: 500px) {

.keyvisual-main-inner:before{
	width: 76%;
}

.keyvisual-main-inner:after {
	right: -30px;
	bottom: -13px;
	width: 70%;
}

.banner-list04 .swiper-wrapper .group{
	width: auto !important;
	padding: 0 !important;
	margin: 10px !important;

}

.banner-list04 .entry-img img{
    border-radius: 5px;
}

.banner-list04 .swiper-slide{
	max-width:270px;
}

.swiper-slide-bottom{
    height: 30px;
}

.swiper-slide-bottom-text{
    font-size: 12px;
}

.functionArea-main{
	margin-top: 30px;
}


}

@media (max-width: 400px) {
    .keyvisual-main, .keyvisual-main-inner {
        height: 390px;
    }

}

@media (max-width: 370px) {
    .keyvisual-h1 {
        font-size: clamp(30px, 10vw, 60px) !important;
	}

    .keyvisual-main, .keyvisual-main-inner {
        height: 350px;
    }

.keyvisual-main-inner:after {
        right: 0;
        width: 65%;
}

    .keyvisual-main-inner:before {
        width: 65%;
    }

}