/*
Template:ystandard
Theme Name:tsugaru-o-e2
*/

body{
width:100%;
height:100%;
margin:0 auto;
padding:0;
font-size:16px;line-height:1.6;
background:#fff;
   overflow-x: hidden;
  font-weight: 400;
}

a{text-decoration:none;}

ol, ul {
    margin: 0;
    padding:0;
}
li{list-style:none;}

h1, h2, h3, h4, h5, h6 {
    margin: 0em;
    padding: 0;
    line-height: 1.5;
    letter-spacing: .05em;
}

h1+h2, h2+h3, h3+h4, h4+h5, h5+h6 {
    margin-top: 0;
}

.entry-content h1, .entry-content h2, .entry-content h3, .entry-content h4, .entry-content h5, .entry-content h6 {
    margin: 0em;}


.entry-content h1+h2, .entry-content h2+h3, .entry-content h3+h4, .entry-content h4+h5, .entry-content h5+h6 {
    margin-top: 0em;
}

td, th {
    border-right:none;
    border-bottom:none;
}

tr {
    border-left:none;
}

amp-img, img {
    vertical-align: bottom;
}

a {
  text-decoration: none;
  color: inherit;
}

p {
    display: block;
    margin-block-start: 0em;
    margin-block-end: 0em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
}

.footer-copy{margin:0 auto;width:100%;color:#000000;}
#footer-poweredby{display:none;}

.grecaptcha-badge{
    visibility: hidden;
}

.global-nav__menu>.menu-item.current-menu-item>a:after {
    width: 0%;
	transition: width .3s;
}
.global-nav__menu>.menu-item.current-menu-item>a:hover:after {
    width: 100%;
	transition: width .3s;
}


.ponly{display:none;}
.monly{display:block;}

.site-branding {
    padding: 0.75em 1em 0.75em 0;
}

.site-header button {
    top:  20%;
}


.entry-content>*{margin:0 auto;padding:0;width:100%;}

.ys-posts.is-card .ys-posts__text>* {
    margin-top: 0;
    margin-bottom: 0;
}

.ys-post__no-image {
    background-color: #ffffff;
}

.nolink {
    color: #62a2d9;
    /*text-decoration: line-through #62a2d9;*/
}
.nolink a{color:#62a2d9;}


.lang-wrap{
  display: flex;
    flex-direction: column;
    justify-content: center;
    margin-left: 0px;
    margin-top: 1em;
    padding: 0;
}
.lang_title{
  font-family: "Ubuntu", sans-serif;
  font-weight: 300;
  font-size: 0.5rem;
  color: #0073be;
  text-align: center;

  margin: 0 0 5px;
}
.lang{
  display: flex;
  justify-content: left;
}
.lang li{
  padding: 0 5px;
}
.lang li a{
 display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    border: 1px solid #ffffff;
    border-radius: 50%;
    font-family: "Ubuntu", sans-serif;
    font-weight: 500;
    font-size: 0.8rem;
    color: #ffffff;
}
.lang li a.lang_current{
  background: #0073be;
  color: #fff;
  pointer-events: none;
}


h2{	color:#0074be;font-size:2em; font-family: "Poppins", sans-serif;
  font-weight: 600;text-align:center;
  position: relative;
  padding: 0rem;
	line-height:1;
}
h2 span{color:#0074be;font-size:0.5em;border-bottom:0.5em;
  display: block;
  margin-bottom: 2em;margin-top: 0.5em;}
h2:before {
  position: absolute;
  bottom: -16px;
  left: calc(50% - 30px);
  width: 60px;
  height: 5px;
  content: '';
  border-radius: 3px;
  background:#e9516f;
}

.no-results__title {
    margin-top: 0;
    font-size: 1.5em;
}

h2.wf{	color:#ffffff;
}

h2.wf span{	color:#ffffff;
}


.scrollwrap{position:relative;width:100%;margin:0 auto;padding:0;top:0;left:0;}
.scrollwrap .topeyeslide{width:100%;height:100%;}

/*topslider*/

.zoom-fade {
  overflow: hidden;
  margin: 0 auto;
		z-index: 1;
	height:100%;
	width:100%;
	
}

.zoom-fade__item {
  object-fit: cover;
 width: 100%;/*各スライダー全体の横幅を画面の高さいっぱい（100%）にする*/
    height:auto;/*各スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
}

.zoom-fade .zoom-fade__item {
  object-fit: contain;
 width: 100%;/*各スライダー全体の横幅を画面の高さいっぱい（100%）にする*/
    height:100%;/*各スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
}

.slick-list {
	margin: 0 0 0 -20px;}


.add-animation {
  animation: zoom-fade 10s both;
}

.zoom-fade2 .add-animation {
  animation: zoom-fade 20s both;
}

@keyframes zoom-fade {

  0% {
    transform: scale(1.1, 1.1);
  }

  100% {
    transform:translatex(30px) scale(1.1, 1.1);
	  
  }

}


.slick-slide img {
    height: 25vh;
    margin: auto;
    max-width: 100%;
    object-fit: cover;
    width: 100%;
}

.slick-slide.middle img {
    height: auto;
}

.container {
    margin-right: auto;
    margin-left: auto;
    padding-right: 0em;
    padding-left: 0em;
    max-width: none;
}

.sectitlewrap{text-align:center;}
.sectitlewrap h2{line-height:1;}

.site-branding .custom-logo  {
    margin-left: 0.5em;
}

.topeyewrap{position: relative;display:flex; flex-direction: column-reverse;}
.scrollwrap{position:relative;width:100%;margin:0 auto;padding:0;top:0;left:0;}
.scrollwrap .topeye{width:100%;}

.hqtitle{margin-top:0em;}

.topeyetitle{width:100%;text-align:center;}
.topeyetitle img{max-width:320px;}
.topeye{    width: 90%;
    border-radius: 24px 0px 0px 24px;
    overflow: hidden;
    margin-left: 10%;
margin-bottom:12px;}


.peyewrap{position:relative;}
.peyewrap h2{font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  position: absolute;
  top:50%;
  left: 50%;
 -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  color: #fff;
  font-size: 1.8rem;
  margin: 0!important;
  padding: 0!important;
	width:100%;
}

.peyewrap h2.hse{width:75%;}

.peyewrap h2 span{font-size:0.25em;color:#ffffff; font-family: "Poppins", sans-serif;}


.peyewrap h2:before {
 content: '';
    position: inherit;
    bottom: 0;
    left: 0;
    width: auto;
    height: 0;
    background: none;
}



section.about {
  background:  linear-gradient(180deg, #ffffff 0%, #ffffff 80%, #ecf2f5 80%, #ecf2f5 100%);
  color: #0067be;
  text-align: center;
  padding: 12px 0 0;
overflow: hidden;
}

.ellipse{
  background: #ffffff;
    border-bottom-left-radius: 50%;
    border-bottom-right-radius: 50%;
    height: 250px;
    margin-left: -100px;
    margin-right: -100px;
    padding-left: 100px;
    padding-right: 100px;
    margin-top: -200px;}


.topcompanyflex{display:flex;margin:0 auto 32px;flex-direction:column-reverse;}
.topcompanyflex.under{margin:0 auto;flex-direction:column;}

.tcftxt {
    width: 100%;
    padding: 0 16px;
}
.tcfimg{width:100%;}


section.information {
 padding: 40px 0;
    text-align: center;
    background: #ecf2f5;
}

section.overview{background:#ffffff;padding: 40px 0;}

section.contact{
	background:#0074be;
 display: block;
    font-weight: bold;
    max-width: 100%;
    text-align: justify;color:#ffffff;padding: 32px 0 136px;position:relative;}

.tcontactimg1{position:absolute;bottom:0;left:27%;}
.tcontactimg1 img{width:100%;max-width:80px;}
.tcontactimg2{position:absolute;bottom:0;right:30%;}
.tcontactimg2 img{width:100%;max-width:56px;}

section.fimage{background:#ffffff;padding: 0px 0 12px;}

.introtxt-pre{      background-color: #ffffff;
    padding: 1em 1em 1.25em;
    color: #0074be;
    width: 100%;
    max-width: 100%;
    margin: 3em auto 0;font-weight:600;line-height:1.5;font-size:0.8em;}

.introtxt-pre h3{margin-bottom:0.3em;font-size:1.6em;font-family: "Noto Sans JP", sans-serif;font-weight:800;
}

.introtxt{font-size:1.15rem;font-weight:600;text-align: left;}

h3.topintroh3{margin-top:1em;}

.infobox{width:100%;
max-width:960px;
margin:0 auto;
}

.innerwrap{width:100%;max-width:960px;margin:0 auto;padding:0 1em;}

.newswrap{
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  margin-top: 20px;
	flex-direction: column;
}

.newswrap h4{color:#0074be;margin-bottom:1em;font-weight:600;}
.newswrap h4 span{display:block;font-size:0.75em;}

.ys-posts__text {
    text-align: left;
}

.lin1,.rin1{width:100%;}

.lin1{margin-bottom:24px;}

.arrow-btn-right {
    text-align: center;
    margin: 16px auto 0;
}



.arrow-btn-right a{
position: relative;
    text-decoration: none;
    display: inline-block;
    color: #e9516f;
    border: 2px solid #e9516f;
    border-radius: 3em;
    padding: 12px 20px 12px 20px;
    text-align: center;
    outline: none;
    transition: ease .2s;
    width: 80%;
    font-size: 1em;
    font-weight: 600;
}

.arrow-btn-right a:hover{
	background:#ffffff;
  color: #e9516f;
  border:2px solid #e9516f;
}

/* 矢印が右に移動 */
.arrow-btn-right a::after{
    content: '';
    position: absolute;
    top:42%;
    right: 20px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #e9516f;
    border-right: 2px solid #e9516f;
    transform: rotate(45deg);
    transition: all .3s;
	color: #e9516f;
}

/*hover時矢印移動*/
.arrow-btn-right a:hover::after{
  right: 16px;
  color: #e9516f;
  border-top: 2px solid #e9516f;
  border-right: 2px solid #e9516f;
}


.arrow-btn-right2{text-align:center;margin:40px auto 0;}

.arrow-btn-right2 a{
position: relative;
    text-decoration: none;
    display: inline-block;
    color: #ffffff;
    border: 2px solid #e9516f;
    border-radius: 3em;
    padding: 12px 20px 12px 20px;
    text-align: center;
    outline: none;
    transition: ease .2s;
    width: 80%;
    font-size: 1em;
    font-weight: 600;
    background: #e9516f;
}

.arrow-btn-right2 a:hover{
	background:#e9516f;
  color: #ffffff;
  border:2px solid;
	position: relative;
    text-decoration: none;
    display: inline-block;
    color: #ffffff;
    border: 2px solid #e9516f;
    border-radius: 3em;
    padding: 12px 20px 12px 20px;
    text-align: center;
    outline: none;
    transition: ease .2s;
    width: 30%;
    font-size: 1em;
    font-weight: 600;
    background: #e9516f;
}

/* 矢印が右に移動 */
.arrow-btn-right2 a::after{
    content: '';
    position: absolute;
    top:42%;
    right: 20px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
    transform: rotate(45deg);
    transition: all .3s;
	color: #e9516f;
}

/*hover時矢印移動*/
.arrow-btn-right2 a:hover::after{
  right: 16px;
  color: #e9516f;
  border-top: 2px solid #ffffff;
  border-right: 2px solid #ffffff;
}

.arrow-btn-right2.mob{text-align:center;margin:20px auto 0;}

.arrow-btn-right3{text-align:center;margin: 0.5rem auto 0;}

.arrow-btn-right3 a{
position: relative;
    text-decoration: none;
    display: inline-block;
    color: #ffffff;
    border: 2px solid #e9516f;
    border-radius: 0.5em;
padding: 8px 18px 8px 8px;
    text-align: center;
    outline: none;
    transition: ease .2s;
    width: 100%;
    font-size: 1em;
    font-weight: 600;
    background: #e9516f;
}

.arrow-btn-right3 a:hover{
background: #e9516f;
    color: #ffffff;
    border: 2px solid;
    position: relative;
    text-decoration: none;
    display: inline-block;
    color: #ffffff;
    border: 2px solid #e9516f;
    border-radius: 0.5em;
    padding: 12px 20px 12px 20px;
    text-align: center;
    outline: none;
    transition: ease .2s;
    width: 100%;
    font-size: 1em;
    font-weight: 600;
    background: #e9516f;
}

/* 矢印が右に移動 */
.arrow-btn-right3 a::after{
  content: '';
    position: absolute;
    top: 42%;
    right: 10px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
    transform: rotate(45deg);
    transition: all .3s;
    color: #e9516f;
}

/*hover時矢印移動*/
.arrow-btn-right3 a:hover::after{
  right: 16px;
  color: #e9516f;
  border-top: 2px solid #ffffff;
  border-right: 2px solid #ffffff;
}

section.overview h2{line-height:1.1;margin-top: 24px;}
section.overview h2 span{margin-top:0.75em;}

table.company-table {
    width: 100%;
    max-width: 800px;
    border-collapse: collapse;
    margin: 0 auto;
    background-color: #fff;
}

.company-table th {
    padding: 8px 16px;
    border: 1px solid #c1e0f1;
	text-align:left;
	display: block;
}
.company-table td {
    padding: 16px;
    border: 1px solid #c1e0f1;
	text-align:left;
	display: block;
}



.company-table th {
    width: 100%;
    text-align: center;
    vertical-align: middle;
    background-color: #0269b3;
    color: white;
    font-weight: 600;
}

.company-table h5{color:#0074be;margin-bottom: 0.1em;font-size: 1em;
}

.company-table li{margin-bottom:0.5em;
}
.company-table li:last-child{margin-bottom:0;}

.company-table li p{
    margin-block-start: 0em;
    margin-block-end: 1em;
line-height: 1.3;}

.company-table strong {
    color: #0269b3;
    font-weight: bold;
}

.fimgwrap{display:flex;flex-wrap:wrap;justify-content:space-between;}

.fimgl{width:37%;}
.fimgc{width:20%;}
.fimgr{width:33%;}

/*footer*/
.f_wrap{text-align:center;margin:0 auto;width:100%;padding: 0 1em;}

.f_wrap img {
    width: 100%;
    max-width: 80%;
    margin: 0 auto;
}

.footer-main>* {
    margin-top: 3em;
}
.fad{margin-top:1.5em;}

.back-to-top__content {
    display: block;
    padding: 0.75em;
	box-shadow:none;
    line-height: 1;
    white-space: nowrap;
    background:none;
    color:none;
}

.back-to-top__content img{width:100%;}

#back-to-top {
bottom: -5vh;
    right: -4vh;
	display:none;
}

.footer-main {
	padding-top: 0em;}
.footer-nav{margin-top:2em;}

.flow-navi__wrapper {
   position: static;
 }

.flow-navi li{margin-bottom:1em;text-align:center;color:#ffffff;}
.flow-navi li:last-child{margin-bottom:0em;}

.flow-navi li a{color:#ffffff;}

.flow-navi li h4{margin-top:0.5em;font-weight:600;font-size: 0.9em;}

.firstbun{background: #e9516f;
    padding: 1em 1.5em;
    border-radius: 24px 0px 0px 24px;
    margin-top: 40px;}
.firstbun img{width:28px;}
.secondbun{background:#e9516f;padding:1em 1.5em;}

.flow-navib ul{display:flex;flex-wrap:wrap;width:100%;align-items: center;}
.flow-navib h4{font-size:1em;}
.firstbunb{ background: #e9516f;
    padding:1em 0.5em;
    width:  75%;
    font-size: .75em;
    text-align: center;
    vertical-align: middle;
     align-self: stretch;}

.firstbunb img{margin-bottom: 0.25em;
    margin-top: 0.25em;
    max-width: 10%;
   }

.secondbunb{background: #0074be;
    padding: 1.25em 0.5em 1em;
    width: 25%;
    font-size: 1.5em;
    text-align: center;
    vertical-align: middle;
    align-self: stretch;}

.firstbunb a,.secondbunb a{color:#ffffff;}


 .flow-navib__wrapper{
   position: static;
 }

#flowbbun {
	width: 100%;
  position: fixed;
    bottom: 0;
    z-index: 2;
    opacity: 0;
    transform: translateY(100px);
}

/*　上に上がる動き　*/

#flowbbun.UpMove{
	animation: UpAnime 0.5s forwards;
}
@keyframes UpAnime{
  from {
    opacity: 0;
	transform: translateY(100px);
  }
  to {
    opacity: 1;
	transform: translateY(0);
  }
}

/*　下に下がる動き　*/

#flowbbun.DownMove{
	animation: DownAnime 0.5s forwards;
}
@keyframes DownAnime{
  from {
  	opacity: 1;
	transform: translateY(0);
  }
  to {
  	opacity: 1;
	transform: translateY(100px);
  }
}

/*footer*/
.footer-nav .menu-item {
    font-size: 1.1em;
	    margin-bottom: 0.25em;
}	
	
	.menu-item a{color:#ffffff;font-weight:600;}

/*arcive*/
.has-sidebar .content__wrap {
 margin:0px;
	padding:0 16px;
}
h2.wp-block-heading{font-size: 1.25em;
    text-align: left;}

h2.wp-block-heading:before {
  position:inherit;
}

:root :where(.is-layout-flow) > * {
    margin-block-start: 0;
}

.breadcrumbs{padding:0 16px;}

h2.archive__title{text-align:left;}
h2.archive__title:before {
  position:inherit;
}
.archive__item.is-simple .archive__category.category--info {
 margin-right:30px;
}

.arctwrap{ width:100%;   margin: 0 auto 24px;display:flex;padding: 0 16px;flex-direction: column;}
h2.arctitle{text-align:left;}
h2.arctitle::before{position: absolute;
    bottom: 0;
    left:0;
    width:auto;
    height:auto;
    content: '';
    border-radius:0;
    background:none;}
h2.arctitle span{display:block;font-size:0.4em;margin-top: 0.25em;}
h2.arctitle span.cat{color:#E9516E;}
.archive__page-title {
    display: none;
}


.btwrap{
    display: flex;
    flex-direction: row;
}

/*安全衛生環境方針*/

section.healthse{margin:40px auto;}


/*お問い合わせ*/

.contactbox{padding:0 1em;}

.contactwrap {
    border: 2px solid  #ecf2f5;
    border-radius: 0.5em;
    padding: 2em 2em;
    max-width: 960px;
    text-align: center;
    margin-bottom: 40px;
    background: #ecf2f5;
}

table.contactt{border-collapse: collapse;
    border-spacing: 0;
    max-width: 840px;
   margin: 0 auto 24px;;
border-top:none;}

.contactt th{
 text-align:left;
	font-size:1em;
 color:#444;
 padding: 8px;
 width:30%;
}

table.contactt th{text-align:center;margin-top: 1em;}
table.contactt th.confirst{margin-top: 0em;}

section.cform{padding: 0px 0rem 40px;}


/*通常欄*/
.contactt td{
 font-size:1em;
}
.contactt td.koumoku{
 font-size:1em;
}

.contactt th p,.contactt td p{margin:0;}

.contactt th p span {
    font-weight: 600;
    font-size: 1.1em;
}

.contactt input,.contactt textarea{border:none;}

.spamtxt1{color:#000000;}
.spamtxt1 a{color:#0074be;text-decoration: underline;}



.priatt{margin-top:1em;}

/*横の行とテーブル全体*/
.entry-content .contactt tr,.entry-content table{
 /*border:solid 1px #d7d7d7;*/
	border:none;
}

/*送信ボタンのデザイン変更*/
#formbtn{
     padding: 12px 16px;
 max-width:350px;
 background:#0074be;
	border:2px solid #0074be;
 color:#ffffff;
 font-size:16px;
 font-weight:bold;	 
 margin:24px auto 0;
	border-radius:3em;
}
/*送信ボタンマウスホバー時*/
#formbtn:hover{
 background:#abc5d9;
 color:#ffffff;
 border:2px solid #abc5d9;
}

input[type=email], input[type=search], input[type=text], input[type=url],  input[type=tel],select, textarea {
    display: block;
    width: 100%;
    -webkit-appearance: none;
}

table.contactt th{
background:none;
}

table.contactt th,table.contactt td {
 display:block;
 width:100%;
 border-top:none;
 -webkit-box-sizing:border-box;
 -moz-box-sizing:border-box;
 box-sizing:border-box;	
    padding: 0 0 4px;
	color:#0074be;
}


div.wpcf7 .ajax-loader{display:none;}


span.caution{font-size:10px;display:block;
    margin-top: 4px;}

.wpcf7-spinner{
	width:0;
	margin:0;
}

.wpcf7-list-item {
    display: inline-block;
    margin: 0 4px 0 0;
}

.policywrap{padding:0 1em;text-align:left;}

.policytxt{margin-bottom:2em;}

.policyul h4{color:#0074be;font-weight:600;}
.policyul li{margin-bottom:2em;}
.policyul li:last-child{margin-bottom:0em;}

.priadd{text-align:right;}


      /* Company Overview Section */
        .company-overview {
            padding: 40px 0rem;
            background: white;
        }

        .section-title {
            text-align: center;
            font-size: 2rem;
            color: #0066cc;
            margin-bottom: 1rem;
            font-weight: bold;
        }

        .section-subtitle {
            text-align: center;
            font-size: 1rem;
            color: #666;
            margin-bottom: 3rem;
        }

     

        /* Message Section */
        .message-section {
            background: #ecf2f5;
            padding: 40px 0rem;
        }

        .message-content {
            max-width: 1000px;
            margin: 0 auto;
        }

        .message-card {
            background: white;
            border-radius: 15px;
            padding: 3rem;
            box-shadow: 0 10px 30px rgba(0,0,0,0.1);
            display: grid;
            grid-template-columns: 1fr;
            gap: 2rem;
            align-items: center;
        }


        .message-text {
            padding: 1rem 0 0;
			text-align:left;
        }

        .message-text p {
            margin-bottom: 1.5rem;
            line-height: 1.8;
        }

        .message-signature {
            text-align:left;
            margin-top: 2rem;
        }

        .message-title {
            font-size: 0.9rem;
            color: #000000;
            margin-bottom: 0.5rem;
        }

        .message-name {
            font-size: 1.2rem;
            font-weight: bold;
            color: #333;
        }

        /* Project Structure Section */
        .structure-section {
            padding: 40px 0rem;
            background: white;
        }

        .structure-content {
            max-width: 1000px;
            margin: 0 auto;
            text-align: center;
        }

        .structure-diagram {
            background: linear-gradient(135deg, #ff9a9e 0%, #fecfef 50%, #fecfef 100%);
            border-radius: 20px;
            padding: 3rem 2rem;
            margin: 3rem 0;
            position: relative;
        }

        .main-company {
            background: white;
            border-radius: 50%;
            width: 120px;
            height: 120px;
            margin: 0 auto 3rem;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            box-shadow: 0 5px 15px rgba(0,0,0,0.1);
        }


        .company-name {
            font-size: 0.8rem;
            font-weight: bold;
            color: #0066cc;
            text-align: center;
        }

        .partners {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 2rem;
            margin-top: 2rem;
        }

        .partner-card {
            background: white;
            padding: 2rem;
            border-radius: 15px;
            box-shadow: 0 5px 15px rgba(0,0,0,0.1);
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            min-height: 150px;
        }

        .partner-logo {
            font-size: 2rem;
            margin-bottom: 1rem;
        }

        .partner-name {
            font-size: 1rem;
            font-weight: bold;
            color: #333;
            text-align: center;
            margin-bottom: 0.5rem;
        }

        .partner-description {
            font-size: 0.8rem;
            color: #666;
            text-align: center;
            line-height: 1.4;
        }

        .structure-arrows {
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 2rem;
            margin: 2rem 0;
        }

        .arrow {
            font-size: 2rem;
            color: #0066cc;
        }

.stcimg.green img{width:70%;margin:0 auto;}
.stcimg.jera img{width:50%;margin:0 auto;}
.stcimg.tohoku img{width:75%;margin:0 auto;}

.stcflex.first{margin-top:2em;}
.stcimg{text-align: center;
    margin: 1em auto 0.5em;}

        /* Content Section */
        .overviewtop {
            padding: 40px 0;
            max-width: 1200px;
            margin: 0 auto;
        }

        .overviewtop p {
            color: #000000;
            line-height: 1.8;
        }

        /* Philosophy Section */
        .philosophy-section {
            background: #ecf2f5;
            padding: 40px 1rem;
            text-align: center;
        }

    .philosophy-content {
            max-width: 960px;
            margin: 0 auto;
        }


    .philosophy-content img {
            max-width: 320px;
        }



.visionwrap{display:flex;flex-wrap:wrap;justify-content:space-between;    align-items: flex-start;flex-direction:column;}

.slide-container {
            width: 100%;
            max-width:480px;
            background:#0074be;
            position: relative;
            border: 2px solid #0074be;;
            overflow: hidden;
	margin-bottom: 24px;
        }

.slide-container.last{
	margin-bottom: 0px;
        }

        .slide-number {
            position: absolute;
            top: 2px;
            left: 2px;
            width: 0;
            height: 0;
            border-left: 65px solid #e9516f;
            border-bottom: 65px solid transparent;
        }

        .slide-number.num1::after {
        content: "1";
    position: absolute;
    top: 5px;
    left: -63px;
    color: white;
    font-size: 28px;
    font-weight: bold;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
        }

 .slide-number.num2::after {
        content: "2";
    position: absolute;
   top: 5px;
    left: -63px;
    color: white;
    font-size: 28px;
    font-weight: bold;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
        }

 .slide-number.num3::after {
        content: "3";
    position: absolute;
    top: 5px;
    color: white;
    font-size: 28px;
    font-weight: bold;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
        }

        .slide-title {
           color: white;
    font-size: 1.4em;
    font-weight: bold;
    text-align: center;
    padding: 40px 40px;
    line-height: 1.5;
    letter-spacing: 2px;
			    height: 100%;
    max-height: 130px;
        }
   .slide-title2 {
           color: white;
    font-size: 1.4em;
    font-weight: bold;
    text-align: center;
    padding: 20px 40px;
    line-height: 1.5;
    letter-spacing: 2px;
	     height: 100%;
    max-height: 130px;
        }

        .content-section {
          background: white;
    padding: 16px;
    margin: 0;
    position: relative;
        }

        .content-section.c3 {
          background: white;
    padding: 16px;
    margin: 0;
    position: relative;
        }

        .content-item {
            margin-bottom: 24px;
            display: flex;
            line-height: 1.6;
        }

        .content-item.last {
            margin-bottom: 0;
        }

        .arrow {
         color: #2E86C1;
    font-size: 16px;
    margin-right: 4px;
    margin-top: 2px;
    flex-shrink: 0;
        }
.arrow::before{content:"\025b6"}

        .content-text {
         font-size: 17px;
    color: #000000;
    letter-spacing: 2px;
			margin-bottom:1em;
        }

.content-text span{color:#e9516f;}

.content-text.first{margin-top:2.5em;}

 .content-item.last .content-text{
            margin-bottom: 0;
        }



/* Project Overview Section */
        .project-overview-section {
            background: #ecf2f5;
            padding: 40px 0;
        }


.project-stats ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem;
    margin: 3rem 0;
    flex-direction: row;
}

  .project-stats ul li{
         width:47.5%;
        }

.vision-section {
            padding: 40px 0rem;
        }
	
        /* Schedule Section */
        .schedule-section {
            padding: 40px 0;
            background: white;
        }

        .schedule-table {
            width: 100%;
            max-width: 960px;
            margin: 3rem auto 0;
           overflow-x: scroll;
			-ms-overflow-style: none;
        }

.schedule-table img{max-width:540px;}



.cap-box {
  width: 100%;
}
.cap-box h3{    color: #0074be;
    text-align: center;
    font-size: 1.4em;}
.cap-box h3::after{content: url(https://tsugaru-oe.co.jp/wp-content/uploads/2025/06/wave.svg);
    display: block;
    margin-top: -4px;
    margin-bottom: 0.5em;
}

.cap-box .cap-box-title {
display: inline-block;
    padding: 0.1em 0.75em 0.1em;
    line-height: 1;
    max-width: 30%;
    background: #fff;
    color: #0074be;
    position: relative;
    top: 0.75em;
    left: 35%;
    font-weight: 600;
    font-size: 2em;
}

.cap-box .cap-box-content {
      border: 4px solid #0074be;
    padding: 2em 1em 3.4em;align-self: center;
}

.cap-box .cap-box-content.c3{
    padding: 2em 1em 2.2em;
}

.cap-box .cap-box-content.c4{
    padding: 2em 1em 9.75em;
}

.cap-box .cap-box-content p {
  margin: 0;
  padding: 1em;
}

.healthse .att{margin:1em 0;}
.healthse ul{margin: 1em 0 1em 2em;}
.healthse ul li{list-style:disc;}
.healthse.nodisk ul li{list-style:none;}
.healthname{text-align:right;margin-top:2em;}


/*採用情報*/
.recruit-section{text-align:center;}
.recruit-section h3{}

@media (min-width: 600px) {
	
.ponly{display:block;}
.monly{display:none;}

#back-to-top {
	display:block;
}

.breadcrumbs{padding:0 80px;}

.toptitlewrap img{max-width:140px;}
	
		.header-type--row1 .global-nav {
    font-size: 1.1em;
    margin-right: 3em;
}
.site-branding .custom-logo  {
    margin-left: 2em;
}
	
	
.nolink{color:#ecf2f5;}
.nolink a{color:#ecf2f5;}
	
.lang-wrap{
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin-left: 30px;
  padding: 0;
	margin-top: 0em;
}
.lang_title{
  font-family: "Ubuntu", sans-serif;
  font-weight: 300;
  font-size: 0.5rem;
  color: #0073be;
  text-align: center;
  margin: 0 0 5px;
}
.lang{
  display: flex;
  justify-content: center;
}
.lang li{
  padding: 0 5px;
}
.lang li a{
 display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    border: 1px solid #0073be;
    border-radius: 50%;
    font-weight: 500;
    font-size: 0.8rem;
    color: #0073be;
}
.lang li a.lang_current{
  background: #0073be;
  color: #fff;
  pointer-events: none;
}	
	
	h2{	font-size:3em;line-height:1.25;
}
	
	/*topslider*/

.zoom-fade {
  overflow: hidden;
  margin: 0 auto;
		z-index: 1;
	height: 95vh;
	width:105%;
	
}

.zoom-fade__item {
  object-fit: cover;
 width: 100%;/*各スライダー全体の横幅を画面の高さいっぱい（100%）にする*/
    height:auto;/*各スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
}

.zoom-fade .zoom-fade__item {
  object-fit: cover;
 width: 100%;/*各スライダー全体の横幅を画面の高さいっぱい（100%）にする*/
    height:80vh;/*各スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
}

.slick-list {
	margin: 0 0 0 -20px;}


.add-animation {
  animation: zoom-fade 10s both;
}

.zoom-fade2 .add-animation {
  animation: zoom-fade 20s both;
}

.slick-slide img {
    height: inherit;
	height: 80vh;
  margin: auto;
  max-height: 100%;
  max-width: 100%;
  object-fit: cover;
  width: 100%;
}
	
	
	.zoom-fade__item {
  object-fit: cover;
 width: 108%;/*各スライダー全体の横幅を画面の高さいっぱい（100%）にする*/
    height:100vh;/*各スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
}
	
	.scrollwrap .topeyeslide{width:100%;height:720px;}
	
	.topeyewrap{flex-direction: row;}
	.topeyetitle{width:25%;text-align:center;align-self: center;}
	
	.topeyetitle img {
    max-width: 180px;
}
	
	.topeye {
    width: 75%;
		margin-left:0;
		margin-bottom:0;
		border-radius: 48px 0px 0px 48px;
}
	
	.ellipse{

    height: 300px;
  }

	h3.topintroh3{margin-top:2em;}
	
	
	.peyewrap h2{
  font-size: 4rem;
}
	
	.topcompanyflex{flex-direction:row;}
	.topcompanyflex h2{font-size:2.5em;}
	.topcompanyflex.under{margin:0 auto;flex-direction:row;}
	
	.tcftxt{width:48%;padding:0 80px;align-self:center;}
.tcfimg{width:52%;}
	
section.information {
 padding: 80px 0 0;
}	
	
section.overview{padding: 80px 0;}
section.overview h2{margin-top:0;}	
	
	section.about {
  padding: 80px 0 0;
	}
	

	
	.innerwrap{padding:0;}
	.introtxt{font-size:1.5rem;font-weight:600;}
.introtxt-pre{      background-color: #ffffff;
    padding: 1em 1em 1.25em;
    max-width: 60%;font-size:1em;}

 
.lin1,.rin1{width:44%;}	
.lin1{margin-bottom:0;}
	
	.newswrap{
	flex-direction: row;
}
	
.arrow-btn-right{text-align:center;margin:40px auto 0;}	

.arrow-btn-right a{
    width: 62%;
}
	
.infobox{padding: 2em 2em 3.5em;}
	
.company-table th, 
.company-table td {
    padding: 16px;
	text-align:left;
	display:table-cell;
}

.company-table th {
    width: 20%;
    text-align: center;
}
	
	.arrow-btn-right {
    margin: 16px auto 0em;
}
	
.arrow-btn-right2 a{
    width: 30%;
}
	
.arrow-btn-right2.mob{
   margin:40px auto 0;
}
	
.arrow-btn-right3{text-align:center;margin: 0.5rem 1rem 0;}

.arrow-btn-right3 a{
	
	
}
	
.arrow-btn-right3 a{
    padding: 12px 30px 12px 12px;
	margin-left:1em;
}

.arrow-btn-right3 a:hover{
background: #e9516f;
    color: #ffffff;
    border: 2px solid;
    position: relative;
    text-decoration: none;
    display: inline-block;
    color: #ffffff;
    border: 2px solid #e9516f;
    border-radius: 0.5em;
    padding: 12px 20px 12px 20px;
    text-align: center;
    outline: none;
    transition: ease .2s;
    width: 100%;
    font-size: 1em;
    font-weight: 600;
    background: #e9516f;
}

/* 矢印が右に移動 */
.arrow-btn-right3 a::after{
    content: '';
    position: absolute;
    top:42%;
    right: 20px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
    transform: rotate(45deg);
    transition: all .3s;
	color: #e9516f;
}

/*hover時矢印移動*/
.arrow-btn-right3 a:hover::after{
  right: 16px;
  color: #e9516f;
  border-top: 2px solid #ffffff;
  border-right: 2px solid #ffffff;
}	
	
/*footer*/
	
.footer-main>* {
    margin-top: 2em;
}	
	
.footer-nav .menu-item {
    font-size: 1.1em;
	border-right: 1px solid #000;
	padding: 0 12px;
    margin: 0 0 16px;
	    line-height: 1.5;
}	
	
	.menu-item a{color:#0067be;font-weight:600;}
	.menu-item:last-child{border-right:none;}
	
/*arcive*/
.has-sidebar .content__wrap {
 margin:80px 80px;
	padding:0;
}
	
.arctwrap {
    width: 100%;
    margin: 0 80px;
    display: flex;
    flex-direction: row;
	padding:0;
}
	
	
	
/*安全衛生環境方針*/

section.healthse{margin:80px auto;}
	
	
/*お問い合わせ*/	
.contactt th p span{
    font-weight: 600;
    font-size: 1.25em;
}
	
	section.cform{padding: 0px 0rem 80px;}

	
section.fimage{background:#ffffff;padding: 0px 0 24px;}	
.f_wrap img {
    width: 100%;
      max-width: 360px;
    margin: 0 auto;
}	
	
	section.contact{text-align:center;color:#ffffff;padding: 56px 0 80px;position:relative;}

.tcontactimg1{position:absolute;bottom:0;left:16%;}
.tcontactimg1 img{width:100%;max-width:200px;}
.tcontactimg2{position:absolute;bottom:0;right:20%;}
.tcontactimg2 img{width:100%;max-width:140px;}	
	
.flow-navi {
  position: fixed;
  top:107px;
	right:0;
  z-index: 3;
}
	
	.flow-navi__wrapper {
  /*display:none;*/
}
	
	.flow-navib__wrapper{
  display:none;
}
	
	button#back-to-top{width: 100px;
    height: 100px;bottom: 3.5vh;
    right: 5vh;}
	
	   .project-stats ul{
			flex-direction:row;
        }
	
	   .company-overview {
            padding: 80px 0rem;
            background: white;
        }
	
	.message-section {
    padding: 80px 0rem;
}
	
	
	   /* Project Structure Section */
        .structure-section {
            padding: 80px 0rem;
        }

	    /* Content Section */
        .content-section {
            padding: 16px 1rem;
			margin: 0 auto;
        }
	
        /* Philosophy Section */
        .philosophy-section {
            padding: 80px 1rem;
        }
	
	 .philosophy-content img {
            max-width: 100%;
        }

	.vision-section {
            padding: 80px 1rem;
        }
	.visionwrap{flex-direction:row;}

	
	 .cap-box {
    width: 32%;
  }
	
.cap-box .cap-box-content.c3{
    padding: 2em 1em 15.1em;
}	
	
	.slide-container {
            width: 32%;
            max-width:300px;
            background:#0074be;
            position: relative;
            border: 2px solid #0074be;;
            overflow: hidden;
        }
	
	.overviewtop {
    padding: 80px 0;
}
	
	 .project-overview-section {
            padding: 80px 1rem;
        }
	
	     .project-stats ul{
            display: flex;
            justify-content: center;
            gap: 2rem;
            margin: 3rem 0;
            flex-wrap: wrap;
			flex-direction:row;
        }
	
	.project-stats ul li {
   width: 30%;
    text-align: center;
}
	
	    .content-section.c3 {
    padding: 16px 16px 45px;
        }
	
	 .content-section.c4 {
    padding: 16px 16px 45px;
        }
	 
	   /* Schedule Section */
        .schedule-section {
            padding: 80px 1rem;
            background: white;
        }

        .schedule-table {
            width: 100%;
            max-width: 960px;
            margin: 3rem auto 0;
        }
	 
	 .schedule-table img{max-width:100%;}
	
}

