@charset "utf-8";
/* ===========================================================
 *
 * 市川鉸工業 スタイルシート
 * Last UpDate : 2026/01/19
 *
=========================================================== */

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

/* ----------------------------------------------------------
 common
---------------------------------------------------------- */
@import "fonts.css";
@import "menu.css";
@import "hover.css";

html{  }
body {
color: #333;
font-family: source-han-sans-japanese,"游ゴシック Medium","Yu Gothic Medium","游ゴシック体",YuGothic,sans-serif;
font-weight: 400;
font-style: normal;
letter-spacing: 1.2px;
background: url("../images/bg_sky01.jpg") no-repeat top center; background-size: cover;
}
/*
@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop, .h2Wrap{ line-height: 1.7 !important; }

}
*/


a.anker{ display: block; padding-top: 100px; margin-top: -100px; }


/* ----------------------------------------------------------
 link
---------------------------------------------------------- */
a:link		{ color: #333; text-decoration: none; }
a:visited	{ color: #333; text-decoration: none; }
a:hover		{ color: #0068b7; text-decoration: none; }
a:active	{ color: #0068b7; text-decoration: none; }

a { -ms-filter: "alpha( opacity=60 )"; -webkit-transition: 0.5s ease-in-out; -moz-transition: 0.5s ease-in-out; -o-transition: 0.5s ease-in-out; transition: 0.5s ease-in-out; }

/* ----------------------------------------------------------
 header
---------------------------------------------------------- */
header{ background: #fff; position: fixed; width: 100%; height: 80px; top: 0; left: 0; z-index: 999; }
#header{ width: 1200px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; }
.headerLogo{ flex-basis: 20%; }
.headerLogo img{ width: 100%; height: auto; }
.headerLogo a:hover{ opacity: 0.6; }
#gNavi{ flex-basis: 52%; }

.emergency{background-color: #f5f5f5; padding: 20px 0; text-align: center;}

.mega-menu{ display: flex; align-items: center; }
.mega-menu > li{ flex-basis: 25%; border-right: 3px solid #ddd; text-align: center; }
.mega-menu > li:first-child{ border-left: 3px solid #ddd; }
.mega-menu > li > a{ display: block; min-height: 50px; padding: 15px 0 5px 0; }
.mega-menu li .gNavi01{ display: flex; justify-content: space-between; }
.mega-menu li .gNavi01Ico{ flex-basis: 40%; text-align: center; }
.mega-menu li .gNavi01Tit{ flex-basis: 55%; font-size: 1.8rem; color: #000; text-align: left; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; }
.mega-menu li .gNavi01Tit span{ display: block; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 600; font-style: normal; font-size: 1rem; letter-spacing: 2px; }
.mega-menu li i{ display: block; text-align: center; font-size: 1.3rem; color: #000; margin-top: 5px; animation: flash 1s linear infinite; }
@keyframes flash {
	0%,100% { opacity: 1; }
	50% { opacity: 0; }
}

.mega-menu li:hover > a,
.mega-menu li > a.current{ background: #0068b7; color: #fff; }
.mega-menu li:hover .gNavi01Tit{ color: #fff; }
.mega-menu li:hover i{ color: #fff; animation: none; }

.current .gNavi01Tit,
.current i{ color: #fff !important; }

/********
メガメニュー
**********/
.mega-menu {
     margin: 0 auto;
     padding: 0 !important;
     position: relative;
}
 
.mega-menu > li {}

 
/***********
 ドロップダウン
************/
.drop {
     display: none;/*ドロップメニューは、デフォルトでは見えないようにする(重要①)*/
     position: absolute; /*ドロップダウンメニューはabsoluteにする(重要②) */
     width: 624px; /*メガメニューの幅と合わせる*/
     left:  0;
	background: #0068b7;
	border-left: 3px solid #ddd;
	border-right: 3px solid #ddd;
	border-bottom: 3px solid #ddd;
}
.drop ul{ display: flex; justify-content: space-between; }
.drop li{ text-align: left; flex: 1 0 auto; } 
.drop li a{ display: block; color: #fff; padding: 20px 10px; font-size: 1.6rem; }
.drop li a i{ display: inline; text-align: left; font-size: 1.3rem; margin-right: 10px; }
.drop li a:hover{ background: #26a3ff; }

.header_tel{ flex-basis: 15%; }
.header_tel_img{}

.header_contact{ flex-basis: 7%; }
.header_contact_img{ text-align: center;  background-color: #086db9; min-height: 80px; padding-top: 16px; }
.header_contact_img:hover{ opacity: 0.6; }

/* ----------------------------------------------------------
 footer
---------------------------------------------------------- */
footer{
	background-image: url("../images/bg_footer_top01.png"),url("../images/bg_footer_bottom01.png");
	background-repeat: repeat-x,repeat-x;
	background-size: auto, auto;
	background-position: top,bottom;
	background-color: #000;
	padding: 90px 0 120px 0; }
#footer{ width: 1200px; margin: 0 auto; }
.footerLogo{ text-align: center; margin: 0 auto 20px auto; }
.footerAdd{ color: #fff; font-size: 1.5rem; text-align: center; margin-bottom: 5px; }
.footerTel{ color: #fff; font-size: 1.5rem; text-align: center; margin-bottom: 20px; }
.footerSitemap{ border-top: 1px solid #fff; padding-top: 40px; display: flex; justify-content: center; }
.footerSitemap ul{ margin: 0 20px; }
.footerSitemap ul li{ color: #fff; font-size: 1.4rem; font-weight: 700; line-height: 1.9; }
.footerSitemap ul li i{ font-size: 1.2rem; margin-right: 5px; animation: flash2 1s linear infinite; }
@keyframes flash2 {
	0%,100% { opacity: 1; }
	50% { opacity: 0; }
}

.footerSitemap ul li a{ color: #fff; }
.footerSitemap ul li a:hover{ opacity: 0.6; }
.footerSitemap ul li ul{ list-style-type: square; margin: 5px 0 0 55px; }
.footerSitemap ul li ul li{ color: #fff; font-size: 1.2rem; font-weight: 400; }
.footerSitemap ul li ul li a{ color: #fff; }

.footerSitemapTit{ display: flex; }
.footer01Ico{ width: 18%; margin-right: 10px; }
.footer01Ico img{ width: 100%; height: auto; }
.footerSitemapTit p{}

/* ----------------------------------------------------------
 hx
---------------------------------------------------------- */
.h1Wrap{ width: 700px; background-color: #111; line-height: 1; text-align: center; border: 3px solid #111; padding: 5px 8px; border-radius: 5px; position: absolute; top: 150px; left: 0; right: 0; margin: auto; }
h1{ font-size: 3.5rem; color: #fff; letter-spacing: 8px; text-align: center; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; display: flex; align-items: flex-end; justify-content: center; }
h1 p.h1p{ color: #fff; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal; font-size: 1.3rem; letter-spacing: 2px; font-weight: normal; margin-left: 30px; }
h1.blink-before::before { content: "\e909"; font-family: 'icomoon'; position: absolute; top: 7px; left: 1rem; font-size: 1.5rem; animation: none; }

.h2Wrap{ width: 700px; background-color: #111; line-height: 1; text-align: center; border: 3px solid #111; padding: 5px 8px; margin: 0 auto 60px auto; border-radius: 5px; }
.h201{ background: #111; border-top: 3px solid #fff; border-bottom: 3px solid #fff; }
.h202{ display: block; padding: 25px; margin: 0 -3px; background-image: url("../images/h2_bg03.png"),url("../images/h2_bg03.png"); background-position: left, right; background-repeat: no-repeat, no-repeat; }
h2{ font-size: 2.7rem; color: #fff; letter-spacing: 8px; text-align: center; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; }
.blink-before{ position: relative; }
.blink-before::before { content: "\e909"; font-family: 'icomoon'; position: absolute; top: 7px; left: 1rem; animation: blink 1.4s infinite; font-size: 1.5rem; }
/* 点滅 */
@keyframes blink {
 50% { opacity: 0; }
}
@-webkit-keyframes blink {
 50% { opacity: 0; }
}

.main h2{ font-size: 5.5rem; color: #0066b7; text-align: center; letter-spacing: 5px; font-weight: 700; margin-bottom: 30px; }
.main h2 span{ display: block; font-size: 2.5rem; color: #111; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal;letter-spacing: 2px; font-weight: normal; }

h3{ width: 400px; border-radius: 10px; padding: 5px; margin-bottom: 30px; background: #0068b7; }
h3 p{ border: 3px solid #fff; color: #fff; font-size: 2.5rem; letter-spacing: 3px; border-radius: 10px; padding: 18px 18px 18px 50px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; }
h3.blink-before::before{ color: #fff; top: 35px; left: 30px; }

h4{ font-size: 2.3rem; color: #333; letter-spacing: 3px; padding: 0 0 0 30px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; position: relative; margin-bottom: 20px; }
h4::before{ content: "\e909"; font-family: 'icomoon'; position: absolute; top: 0px; left: 0; color: #0068b7; font-size: 2rem; }

/* ぱんくず */
#breadcrumbs{ width: 1200px; margin: 0 auto; }  
#breadcrumbs ol{  } 
#breadcrumbs ol li{ display: inline-block; position: relative; }
#breadcrumbs ol li:before{ content: ">"; display: block; position: absolute; top: .5em; left: 0px; color: #333; font-size: 1.3rem; font-family: a-otf-ryumin-pr6n, serif; font-weight: 300; font-style: normal; }
#breadcrumbs ol li:first-child:before{ content: ""; }
#breadcrumbs ol li a{ color: #aaa; font-size: 1.3rem; margin: 0 0 0 13px; }
#breadcrumbs ol li:first-child a{ margin: 0 0 0 0; }
#breadcrumbs ol li a:hover{ opacity: 0.6; }
/* ----------------------------------------------------------
 contents
---------------------------------------------------------- */
.wrapper{ padding-top: 120px; }
.contents{ background: #fff; margin-top: 80px; padding-top: 150px; }
.main{ width: 1200px; margin: 0 auto; }
.mainSecTxt{ font-size: 1.7rem; color: #333; text-align: center; line-height: 1.8; margin-bottom: 60px; }
.downArrow{ text-align: center; margin-bottom: 60px; }
.downArrow i{ margin: 0 3px; }


.layerSec{ background: rgba(255,255,255,0.9); padding: 40px; width: 700px; margin: 0 auto; position: relative; }
.layerSecBtn{ width: 200px; margin: 30px auto 0 auto; }
.layerSecBtn a{ display: block; text-decoration: none; text-align: center; color: #000; border: 2px solid #000; background: rgba(255,255,255,0.6); padding: 10px; }
.layerSecBtn a:hover{ background: rgba(0,0,0,0.1); }
.layerSecBtn02{ position: absolute; right: -10px; top: -10px; }
.layerSecBtn02 a{ display: block; background: #fff; width: 30px; height: 30px; text-align: center; line-height: 30px; border-radius: 100%; border: 2px solid #000; }
.layerSecBtn02 a i{ font-size: 18px; color: #000; }


.topMovie{ width: 1100px; margin: 0 auto; background: #ddd; border-radius: 15px; padding: 40px 40px 20px 40px; box-shadow: 2.5rem 2.5rem 2rem -2rem hsl(200 50% 20% / 40%); }
.topMovieSec{ border-top: 8px solid #b1b1b1; border-right: 8px solid #b1b1b1; }
.topMovieSec01{ position: relative; width: 100%; padding-top: 56.25%; }
.topMovieSec01 video{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.topMovie ul{ display: flex; justify-content: space-between; margin-top: 10px; }
.topMovie li{ font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal; font-size: 1.4rem; position: relative; padding-left: 25px; }
.topMovie li:before{ display: block; content: ""; position: absolute; left: 0; top: 1px; width: 8px; height: 8px; border-radius: 100%; background: #d9d900; border: 4px solid #d9a300;  }

.topNews{ display: flex; justify-content: space-between; flex-wrap: wrap; width: 1250px; margin: 0 auto; background: url("../images/bg_news01.png") no-repeat top center; padding: 100px 40px 60px 40px; }
.topNews01{ flex-basis: 48%; }
.topNews01 ul{}
.topNews01 li{ display: flex; justify-content: space-between; flex-wrap: wrap; align-items: center; padding: 20px; border-bottom: 2px solid #bba076; }
.topNewsDate{ flex-basis: 20%; font-size: 1.4rem; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal; }
.topNewsDate i{ font-size: 1.2rem; margin-right: 10px; animation: flash2 1s linear infinite; }
@keyframes flash2 {
	0%,100% { opacity: 1; }
	50% { opacity: 0; }
}
.topNewsTit01{ flex-basis: 80%; font-size: 1.6rem; font-weight: 700; }
.topNewsTxt01{ flex-basis: 100%; font-size: 1.4rem; margin-top: 10px; }
.topNewsTxt01 a{ color: #0066b7; text-decoration: underline; }
.topNewsTxt01 a:hover{ text-decoration: none; }

.top_news_bnr{ flex-basis: 100%; max-width: 700px; margin: 0 auto 20px; text-align: center;}
.top_news_bnr img{width: 100%; height: auto;}


.top_column01{ flex-basis: 48%; }

.top_news_tit01{ position: relative; font-size: 2rem; color: #222; font-weight: 700; letter-spacing: 2px; padding: 12px 10px 10px 55px; background-color: transparent; }
.top_news_tit01::before { content: "\e909"; font-family: 'icomoon'; position: absolute; top: 16px; left: 25px; font-size: 1.5rem; animation: none; color: #fff; z-index: 2; }
.top_news_tit01::after { position: absolute; content: ""; display: block; top: 10px; left: 10px; width: 35px; height: 35px; background-color: #0068b7; }


.top_column_item{ padding: 20px; border-bottom: 2px solid #bba076; }

.top_column_date{ display: flex; align-items: center; margin-bottom: 5px; }

.top_column_cat01{ margin-left: 10px; }
.top_column_cat01 .category{ background-color: #c09a14; color: #fff; padding: 1px 5px; font-size: 1.4rem; }


.top_column_btn01{ margin-top: 10px; text-align: right; }
.top_column_btn01 a{ display: block; font-size: 1.4rem; font-weight: 700; }

.top_column_btn01 a{ position: relative; padding: 0 0 0 1em; font-size: 1.4rem; letter-spacing: 1px; margin-bottom: 10px; }
.top_column_btn01 a{ display: block; }
.top_column_btn01 a img{ vertical-align: middle; }
.top_column_btn01 a:hover{ opacity: .6; }


.typ1,
.typ2,
.typ3{ opacity: 0; }
.typ1 span,
.typ2 span,
.typ3 span{ opacity: 0; }


.ecBnr{ width: 600px; margin: 0 auto 30px auto; }
.ecBnr a:hover{ opacity: 0.6; }

.topTechnology{ background: url("../images/bg_technology01.jpg") no-repeat; background-size: cover; padding: 170px 0 80px 0; position: relative; }
.topTechnologyH2{ position: absolute; width: 700px; top: -50px; left: 0; right: 0; margin: auto; }
.topTechnology01{ width: 910px; margin: 0 auto; }
.topTechnology01 ul{ display: flex; justify-content: space-between; }
.topTechnology01 li{ flex-basis: 30%; text-align: center; }
.topTechnology01 li a{ display: block; width: 270px; height: 426px; position: relative; overflow: hidden; }
.topTechnology01 li a:before{ content: ""; display: block; position: absolute; width: 100%; height: 100%; top: 0; left: -100%; background: linear-gradient(30deg, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0) 75%);  }
.topTechnology01 li a:hover:before{ animation: shine .3s ease-in-out; }
@keyframes shine {
  100% {
    left: 100%;
  }
}
.topTechnologyImg{ position: relative; }
.topTechnologyImgPress{ background-image:url("../images/tit_bg_press01.png"),url("../images/btn_press01.jpg"); background-repeat: no-repeat,no-repeat; background-position: bottom, top; }
.topTechnologyImgPlate{ background-image: url("../images/tit_bg_plate01.png"),url("../images/btn_plate01.jpg"); background-repeat: no-repeat,no-repeat; background-position: bottom, top; }
.topTechnologyImgSpinning{ background-image: url("../images/tit_bg_spinning01.png"), url("../images/btn_spinning01.jpg"); background-repeat: no-repeat, no-repeat; background-position: bottom, top; }
.topTechnologyTit01{ position: absolute; left: 0; right: 0; margin: 0 auto; bottom: 15px; color: #fff; font-size: 1.8rem; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; }


.topProducts{ background: url("../images/bg_products01.jpg") no-repeat center bottom; background-size: cover; padding: 100px 0 80px 0; width: 100%; height: 680px; }
.topProducts ul{ width: 1200px; margin: 200px auto 0 auto; display: flex; justify-content: space-between; }
.topProducts li{ flex-basis: 25%; text-align: center; background: url("../images/img_desk01.png") no-repeat center center; width: 286px; height: 236px; position: relative; }

.topProductsSecImg{ position: absolute; top: -100px; left: 0; right: 0; margin: 0 auto; }
.topProductsSecImg img{ transition-duration: 0.5s; }
.topProductsSecImg:hover img{ transform: rotateY( 360deg ); transition-duration: 0.5s; }
.topProductsSecTit{ position: absolute; bottom: 55px; left: 0; right: 0; margin: 0 auto; color: #fff; font-size: 1.8rem; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; }


.topNav{ background: url("../images/bg_products01.jpg") no-repeat center bottom; background-size: cover; padding: 50px 0 80px 0; width: 100%; height: 480px; }
.topNav ul{ width: 1200px; margin: 100px auto 0 auto; display: flex; justify-content: center; align-items: flex-end; }
.topNav li{ flex: 1 0 auto; margin: 0 40px; }
.topNavSecImg img{ transition: all 0.6s ease 0s; }
.topNavSecImg:hover img{ transform: scale(1.1, 1.1); }


.topHaisou{ background: url("../images/bg_haisou01.png") repeat-x; margin-bottom: 60px; }
.topHaisou{}

.demo_item{
	width: 464px;
    height: 356px;
    border-radius: 10px;
    background-image: url("../images/img_haisou01.png");
    background-size: 100% 100%;
    background-position: 0 0;
    background-repeat: no-repeat;
    display: block;
    position: relative;
    

}
.demo_item.anime{
    animation-name: upDown;
    animation-iteration-count: infinite;
    animation-duration: 0.1s;
    animation-direction: normal;
    animation-timing-function: steps(2);
    transition-duration: .3s;
    transition-property: transform;
}


.demo_stage{
    position: relative;
    width: 100%;
    height: 488px;
    top: 0px;
    display: block;
	background-image: url("../images/bg_haisou01.png");
	background-repeat: repeat-x;
}


.demo_wrap{
	display: block;
    position: absolute;
    top: 70px;
    animation-fill-mode: forwards;
    animation-timing-function: linear;
    animation-duration: 15s;
    animation-iteration-count: 1;
	margin-right: -25px;
}


.demo_wrap[data-order="left"] {
    /* animation-name: GoLeft; */
	animation: GoLeft 15s ease-in-out 0s infinite normal
}
/*
.demo_wrap[data-order="right"] {
    animation-name: GoRight;
}

.demo_wrap[data-order="right"] > .demo_item {
    transform: rotateY(180deg);
}
*/
@keyframes GoLeft {
    0% {
        right: 10%;
    }
    100% {
        right: 70%;
    }
}
@keyframes GoRight {
    0% {
        right: 70%;
    }
    100% {
        right: 10%;
    }
}

@keyframes upDown {
    0% {
        top: 0;
    }
    100% {
        top: 3px;
    }
}



.mapSec{}
.mapSec01{ position: relative; padding-bottom: 23.3%; padding-top: 30px; height: 0; overflow: hidden; }
.mapSec01 iframe,
.mapSec01 object,
.mapSec01 embed{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; filter: grayscale(100%); }



.technologySec{}
.technologySec > ul{ }
.technologySec > ul > li{ padding-bottom: 120px; background: url("../images/border_dash01.png") repeat-x left; background-position: bottom; margin-bottom: 120px; }
.technologySec > ul > li:last-child{ padding-bottom: 0; background: none; margin-bottom: 120px; }
.technologySec01 > ul{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.technologySec01 > ul > li{}
.technologySec01 > ul > li:nth-child(1){ flex-basis: 36%; }
.technologySec01 > ul > li:nth-child(2){ flex-basis: 58%; }
.technologySec01{}
.technologySec01 h3{ width: 300px; border-radius: 5px; padding: 5px; margin-bottom: 30px; }
.technologySec01 h3 p{ border: 3px solid #fff; color: #fff; font-size: 2.5rem; text-align: center; letter-spacing: 3px; border-radius: 5px; padding: 20px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; }
.technologySec01 h3.blink-before::before{ color: #fff; top: 35px; left: 30px; }
.technologySec01Txt{}
.technologySec01Txt01{ font-size: 1.7rem; line-height: 1.7; margin-bottom: 30px; }
.technologySec01Btn{ width: 250px; margin-bottom: 20px; }
.technologySec01Btn a{ display: block; font-size: 1.8rem; font-weight: 700; text-align: center; padding: 10px; border: 2px solid; letter-spacing: 2px; }
.technologySec01Btn a i{ margin-right: 10px; font-size: 1.5rem; }
.technologySec01Btn a:hover{ color: #fff !important; }

.technologySec01Img{}
.technologySec01Img > ul{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.technologySec01Img > ul > li{}
.technologySec01Img > ul > li img{ width: 100%; height: auto; }
.technologySec01Img > ul > li:nth-child(1){ flex-basis: 100%; margin-bottom: 10px; }
.technologySec01Img > ul > li:nth-child(2),
.technologySec01Img > ul > li:nth-child(3){ flex-basis: 49%; }

.bgOrange{ background: #f15a24; }
.coOrange{ color: #f15a24 !important; }
.boOrange{ border-color: #f15a24 !important; }

.bgBlue{ background: #6c93cc; }
.coBlue{ color: #6c93cc !important; }
.boBlue{ border-color: #6c93cc !important; }

.bgGreen{ background: #438943; }
.coGreen{ color: #438943 !important; }
.boGreen{ border-color: #438943 !important; }

.bgBlack{ background: #000; }
.coBlack{ color: #000 !important; }
.boBlack{ border-color: #000 !important; }

a.coOrange:hover{ background: #f15a24; }
a.coGreen:hover{ background: #438943; }
a.coBlue:hover{ background: #6c93cc; }
a.coBlue:hover{ background: #6c93cc; }
a.coBlack:hover{ background: #000; }


.footerContact{ position: relative; min-height: 243px; margin: 100px 0; }
.footerContactTit{ position: absolute; background: url("../images/bg_contact01.png") no-repeat; width: 410px; height: 70px; font-size: 2.5rem; letter-spacing: 3px; color: #fff; padding: 18px 10px 15px 50px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; z-index: 2; }
.footerContactTit::before{ content: "\e909"; font-family: 'icomoon'; position: absolute; top: 23px; left: 25px; font-size: 1.5rem; animation: none; }
.footerContactTit span{ color: #fff; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 600; font-style: normal; font-size: 1.3rem; letter-spacing: 2px; margin-left: 20px; }
.footerContactSec{ position: absolute; top: 40px; right: 0; background: url("../images/bg_contact02.png") no-repeat; width: 1064px; height: 213px; padding: 40px; }
.footerContactSecTit{ font-size: 2rem; color: #666; letter-spacing: 1px; font-weight: 700; margin-bottom: 20px; }
.footerContactSecTxt{ display: flex; justify-content: space-between; }
.footerContactSecNum{ flex-basis: 60%; display: flex; justify-content: space-between; flex-wrap: wrap; align-items: center; }
.footerContactSecNum p{ flex-basis: 85%; font-size: 6.5rem; color: #0066b7; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal; line-height: 1; letter-spacing: 4px; }
.footerContactSecNum i{ flex-basis: 60px; display: block; width: 60px; height: 60px; text-align: center; line-height: 60px; background: #0066b7; color: #fff; font-size: 2rem; }
.footerContactSecNum span{ flex-basis: 100%; display: block; font-size: 1.6rem; color: #666; font-family: source-han-sans-japanese, sans-serif; font-weight: 700; font-style: normal; text-align: right; margin-right: 80px; }
.footerContactSecBtn{ flex-basis: 35%; width: 400px; }
.footerContactSecBtn a{ display: block; font-size: 2.3rem; color: #fff; font-weight: 700; background: #111; padding: 15px; text-align: center; border: 3px solid #111; }
.footerContactSecBtn a i{ margin-right: 20px; }
.footerContactSecBtn a:hover{ background: #fff; color: #111; }

.mainNav{ width: 1060px; margin: 0 auto 60px auto; }
.mainNav02{ width: 790px; margin: 0 auto 60px auto; }
.mainNav ul,
.mainNav02 ul{ display: flex; justify-content: center; }
.mainNav li{ flex-basis: 23%; margin: 0 1%; }
.mainNav02 li{ flex-basis: 31%; margin: 0 1%; }
.mainNav a,
.mainNav02 a{ display: block; color: #0068b7; font-size: 1.8rem; font-weight: 700; letter-spacing: 2px; padding: 10px 20px; border: 3px solid #0068b7; }
.mainNav a i,
.mainNav02 a i{ margin-right: 10px; }
.mainNav a:hover,
.mainNav02 a:hover{ background: #0068b7; color: #fff; }


.productsSec{}

.productsSec h3{ width: 400px; border-radius: 5px; padding: 5px; margin-bottom: 30px; }
.productsSec h3 p{ border: 3px solid #fff; color: #fff; font-size: 2.5rem; letter-spacing: 3px; border-radius: 5px; padding: 20px 20px 20px 50px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; }
.productsSec h3.blink-before::before{ color: #fff; top: 35px; left: 30px; }

.productsSec > ul{}
.productsSec > ul > li,
.equipmentSec > ul > li,
.companySec > ul > li,
.contactSec > ul > li{ padding-bottom: 120px; background: url("../images/border_dash01.png") repeat-x left; background-position: bottom; margin-bottom: 120px; }
.productsSec > ul > li:last-child,
.equipmentSec > ul > li:last-child,
.companySec > ul > li:last-child,
.contactSec > ul > li:last-child{ padding-bottom: 0; background: none; margin-bottom: 120px; }


.productsSecTxt{ font-size: 1.7rem; line-height: 1.7; margin-bottom: 40px; }
.productsSec01{}
.productsSec01 > ul{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.productsSec01 > ul > li{ flex-basis: 32%; margin-bottom: 40px; }
.productsSec01Img{ margin-bottom: 10px; }
.productsSec01Tit{ font-size: 2rem; color: #535353; letter-spacing: 2px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; margin-bottom: 10px; }

.productsSec01Txt{ padding: 20px; font-size: 1.5rem; line-height: 1.7; background: url("../images/bg_txt01.png") no-repeat; width: 380px; height: 137px; }
.productsSec01Txt span{ font-weight: 700; }


.productsSecPress i{ color: #438943; margin-right: 10px; }
.productsSecHerashibori i{ color: #f15a24; margin-right: 10px; }
.productsSecBankin i{ color: #6c93cc; margin-right: 10px; }
.productsSecFukugou i{ color: #000; margin-right: 10px; }


.equipmentSec{}
.equipmentSecTxt{ font-size: 1.7rem; line-height: 1.7; margin-bottom: 60px; }


.movieSec{}
.movieSec > ul{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.movieSec > ul > li{ flex-basis: 49%; margin-bottom: 40px; }
.movieSec01{ position: relative; width: 100%; padding-top: 56.25%; }
.movieSec01 iframe{ position: absolute; top: 0; right: 0; width: 100%; height: 100%; }
.movieSecTxt{ font-size: 1.7rem; line-height: 1.7; }


.equipmentSec01{ width: 1120px; margin: 0 auto 60px auto; }
.equipmentSec table{ width: 100%; border-collapse: collapse; }
.equipmentSec table th{ background: #666; color: #fff; padding: 15px; }
.equipmentSec table th:nth-child(1),
.equipmentSec table th:nth-child(6){ width: 8%; }
.equipmentSec table th:nth-child(2),
.equipmentSec table th:nth-child(3),
.equipmentSec table th:nth-child(4),
.equipmentSec table th:nth-child(5){ width: 21%; }
.equipmentSec table td{ padding: 15px; border-bottom: 1px solid #ccc; }


.companySec{}

.greetingSec{}
.greetingSec > ul{ display: flex; justify-content: space-between; }
.greetingSec > ul > li:nth-child(1){ flex-basis: 60%; }
.greetingSec > ul > li:nth-child(2){ flex-basis: 35%; text-align: center; }
.greetingSecTxt{}
.greetingSecTxt p{ font-size: 1.8rem; line-height: 1.8; margin-bottom: 30px; }
.greetingSec .footerContactTit{ margin: 0 auto; }
.greetingSec .footerContactTit span{ font-size: 1.8rem; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; letter-spacing: 4px; }
.greetingSec .mr20{ margin-right: 20px; }

.greetingSecImg{ text-align: center; }
.greetingSecImg img{ margin-bottom: 20px; }
.greetingSecName{ width: 360px; border-radius: 10px; padding: 5px; background: #111; margin: 0 auto; }
.greetingSecName p{ border: 3px solid #fff; color: #fff; font-size: 2.5rem; letter-spacing: 3px; border-radius: 10px; padding: 15px 15px 15px 45px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; }
.greetingSecName span{ font-size: 1.8rem; margin-right: 30px; }
.greetingSecName.blink-before::before{ color: #fff; top: 32px; left: 30px; }


.profileSec,
.historySec{ width: 1120px; margin: 0 auto 60px auto; }
.profileSec dl,
.historySec dl{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.profileSec dt,
.historySec dt{ flex-basis: 20%; padding: 15px; border-bottom: 1px solid #ccc; text-align: center; font-weight: 500; }
.profileSec dd,
.historySec dd{ flex-basis: 80%; padding: 15px; border-bottom: 1px solid #ccc; }

.profileSecImg{ width: 100%; margin-bottom: 80px; }
.profileSecImg > ul{ display: flex; justify-content: space-between; }
.profileSecImg > ul > li{ flex-basis: 49%; }
.profileSecImg > ul > li img{ width: 100%; height: auto; }

.accessSec{ width: 1120px; margin: 0 auto 60px auto; }

.haisouSec{ width: 1000px; margin: 0 auto 60px auto; }
.haisouSecTxt{ width: 880px; font-size: 1.6rem; line-height: 1.7; margin-bottom: 60px; }


.contactSec{ width: 980px; margin: 0 auto 60px auto; }
.attachedFileArea li{ margin-bottom: 10px !important; }

.privacySec p{ font-size: 1.6rem; line-height: 1.7; }
.privacySec p.mb20{ margin-bottom: 20px; }
.privacySecTxt{ margin-bottom: 40px; }
.privacySecTxt ol{ margin-left: 30px; margin-top: 10px; }
.privacySecTxt ol li{ list-style-type: decimal; font-size: 1.6rem; }

.thanksSec p{ margin-bottom: 20px; text-align: center; }
.thanksSec p.att{ color: #c00; font-weight: 700; }

.sitemapSec{ width: 980px; margin: 0 auto 60px auto; }
.sitemapSec ul{ }
.sitemapSec ul li{ font-size: 2.4rem; font-weight: 700; line-height: 1.9; }
.sitemapSec ul li i{ font-size: 1.8rem; margin-right: 5px; animation: flash2 1s linear infinite; }

.sitemapSec ul li a{  }
.sitemapSec ul li a:hover{ opacity: 0.6; }
.sitemapSec ul li ul{ margin: 5px 0 20px 70px; }
.sitemapSec ul li ul li{ font-size: 1.8rem; font-weight: 400; list-style-type: square; }
.sitemapSec ul li ul li a{ }

.sitemapSecTit{ display: flex; align-items: center; }
.sitemapIco{ width: 3%; margin-right: 10px; }
.sitemapIco img{ width: 100%; height: auto; vertical-align: middle; }
.sitemapSecTit p{}



.emergency{background-color: #f5f5f5; padding: 30px 0; text-align: center; margin-bottom: 80px;}
.emergency p{margin-bottom: 20px;}
.emergency .emergency_tel{font-size: 2rem; font-weight: 700;}



/* 新設備導入 */
.sp_br{display: none;}
.trulaser_sec{max-width: 1100px; margin: 0 auto; font-family: source-han-sans-japanese, sans-serif;}
.trulaser_sec h2{font-family: source-han-sans-japanese, sans-serif; font-weight: 700; font-size: 4rem; margin-bottom: 25px; letter-spacing: 2px; text-align: center;}
.trulaser_main_sec{margin-bottom: 50px;}
.trulaser_main_img{max-width: 1000px; margin: 0 auto 30px;}
.trulaser_main_img img{width: 100%; height: auto;}
.trulaser_main_txt{font-size: 1.6rem; line-height: 30px; max-width: 720px; margin: 0 auto;}
.trulaser_movie_sec{margin-bottom: 60px;}
.trulaser_movie_inner{display: flex; gap: 50px; justify-content: center;}
.trulaser_movie_item{width: calc((100% - 50px)/2);}
.trulaser_movie_item video{width: 100%; height: auto;}
.trulaser_technology_sec{margin-bottom: 60px;}
.trulaser_technology_list{max-width: 780px; margin: 0 auto; display: flex; flex-direction: column; gap: 15px; }
.trulaser_technology_list li{padding: 15px 30px; background-color: #f5f5f5; font-size: 2rem; font-weight: 700; border-radius: 8px;}
.trulaser_size_sec{margin-bottom: 50px;}
.trulaser_size_img{padding: 50px 0 0; text-align: center;}

.trulaser_material_sec{margin-bottom: 70px;}
.trulaser_material_head{font-size: 2.8rem; font-weight: 700; padding: 8px 0; background-color: #a3a3a3; text-align: center;}
.trulaser_material_table{width: 100%;}
.trulaser_material_table th,
.trulaser_material_table td{padding: 15px; text-align: left; font-size: 1.6rem; border: 1px solid #ccc;}
.trulaser_material_table thead th{background-color: #eee; font-weight: 700;}
.trulaser_material_table th:first-child,
.trulaser_material_table td:first-child{width: 30%;}

.trulaser_material_table02 th:first-child,
.trulaser_material_table02 td:first-child{width: 50%;}

.trulaser_sample_sec{max-width: 1130px;}
.trulaser_sample_list{display: flex; gap: 40px;}
.trulaser_sample_list li{width: calc((100% - 80px)/3); }
.trulaser_sample_list img{margin-bottom: 10px; width: 100%; height: auto;}
.trulaser_sample_list p{font-size: 1.5rem;}



/* ----------------------------------------------------------
 SP CSS
---------------------------------------------------------- */
@media screen and (max-width:680px){
img,video {
  max-width: 100%;
  height: auto;
}

/* フォントサイズ10px=62.5% */
html{ font-size: 60%; }

/* 基本のフォントサイズ */
body{ font-size: 1.8rem; height: auto !important; height: 100%; background-image: none; padding-top: 0; }

/* 非表示用 */
.noneSP		{ display: none !important; }
/* ----------------------------------------------------------
 link
---------------------------------------------------------- */
/* ----------------------------------------------------------
 header
---------------------------------------------------------- */
header{ height: 45px; top: 0; left: 0; z-index: 999; }
#header{ width: 100%; background-color: #fff;}
.headerLogo{ flex-basis: 50%; text-align: center; padding: 10px; }
.headerLogo img{ width: 80%; margin: 0 auto; }
.headerLogo a:hover{ opacity: 0.6; }
#gNavi{ flex-basis: 40%; margin-right: 46px; }

.mega-menu{ display: flex; align-items: center; }
.mega-menu > li{ flex-basis: 25%; border-right: 1px solid #ddd; text-align: center; }
.mega-menu > li:first-child{ border-left: 1px solid #ddd; }
.mega-menu > li > a{ display: block; min-height: 30px; padding: 10px 3px 5px 3px; }
.mega-menu li .gNavi01{ display: flex; justify-content: space-between; }
.mega-menu li .gNavi01Ico{ flex-basis: 100%; text-align: center; }
.mega-menu li .gNavi01Tit{ display: none; }
.mega-menu li i{ display: none; }


.mega-menu li:hover > a,
.mega-menu li > a.current{ background: #0068b7; color: #fff; }
.mega-menu li:hover .gNavi01Tit{ color: #fff; }
.mega-menu li:hover i{ color: #fff; animation: none; }


/***********
 ドロップダウン
************/
.drop {
     display: none; border: 0; background: none;
}
.drop ul{ display: none; }

/*ドロワー*/
.l-drawer{ position: relative; }
.l-drawer__checkbox{ display: none; }
.l-drawer__icon{
	cursor: pointer;
	display: block;
	width: 46px;
	height: 46px;
	position: fixed;
	top: 0px;
	right: 0px;
}
.l-drawer__icon-parts, .l-drawer__icon-parts:before, .l-drawer__icon-parts:after{
	background-color: #0068b7;
	display: block;
	width: 26px;
	height: 2px;
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	margin: auto;
}
.l-drawer__icon-parts:before, .l-drawer__icon-parts:after{ content: " "; }
.l-drawer__icon-parts:before{ transform: translateY(9px); }
.l-drawer__icon-parts:after{ transform: translateY(-9px); }
.l-drawer__overlay{
	background: #000;
	opacity: 0;
	pointer-events: none;
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	right: 0;
}
.l-drawer__menu{
	background: rgba(255,255,255,0.9);
	color: #000;
	max-width: 100%;
	width: 100vw;
	height: 100vh;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	position: fixed;
	top: 0;
	right: -100vw;
}
.l-drawer__icon{ z-index: 999; }
.l-drawer__menu{ z-index: 998; }
.l-drawer__overlay{ z-index: 99; }
.l-drawer__checkbox:checked ~ .l-drawer__icon .l-drawer__icon-parts{ background: transparent; }
.l-drawer__checkbox:checked ~ .l-drawer__icon .l-drawer__icon-parts:before{ -webkit-transform: rotate(-45deg); transform: rotate(-45deg); top: 0; }
.l-drawer__checkbox:checked ~ .l-drawer__icon .l-drawer__icon-parts:after{ -webkit-transform: rotate(45deg); transform: rotate(45deg); top: 0; }
.l-drawer__checkbox:checked ~ .l-drawer__overlay{ opacity: 0.3; pointer-events: auto; }
.l-drawer__checkbox:checked ~ .l-drawer__menu{ right: 0; }
.l-drawer__icon-parts, .l-drawer__icon-parts:after, .l-drawer__icon-parts:before, .l-drawer__overlay, .l-drawer__menu{ -webkit-transition: all 0.7s; transition: all 0.7s; }

nav.l-drawer__menu{ padding: 40px 30px 80px 30px; }
nav.l-drawer__menu > ul > li{ display: block; color: #333; padding: 0 10px 0 20px; position: relative; font-size: 2.2rem; line-height: 3em; letter-spacing: 1px; }
nav.l-drawer__menu > ul > li a{ color: #333; }
nav.l-drawer__menu > ul > li a:hover{ opacity: 0.6; }
nav.l-drawer__menu > ul > li:after{ position: absolute; content: ""; display: block; top: 1.1em; left: 0; width: 10px; height: 10px; background-color: #86c02e; border-radius: 100%; }
nav.l-drawer__menu > ul > li > ul{ margin: 0 0 10px 20px; }
nav.l-drawer__menu > ul > li > ul > li{ font-size: 1.8rem; line-height: 1.8em; }
nav.l-drawer__menu > ul > li > ul > li:before{ font-family: 'icomoon'; content: "\e90e"; font-size: 1rem; color: #86c02e; font-weight: bold; margin-right: 5px; }



ul.headerSns{ width: 100%; margin-top: 10px; }
ul.headerSns li:after{ display: none !important; }
ul.headerSns > li.footerYoutube{ padding: 0; line-height: 1.5; margin-bottom: 10px; }
ul.headerSns > li.footerYoutube a{ display: block; color: #fff; font-size: 1.8rem; text-align: center; background: #f8031b; border: 1px solid #f8031b; border-radius: 5px; padding: 10px; }
ul.headerSns > li.footerYoutube a i{ margin-right: 5px; }
ul.headerSns > li.footerYoutube a:hover{ background: #fff; color: #f8031b; }
ul.headerSns > li.footerFacebook{ padding: 0; line-height: 1.5; margin-bottom: 10px; }
ul.headerSns > li.footerFacebook a{ display: block; color: #fff; font-size: 1.8rem; text-align: center; background: #375794; border: 1px solid #375794; border-radius: 5px; padding: 10px; }
ul.headerSns > li.footerFacebook a i{ margin-right: 5px; }
ul.headerSns > li.footerFacebook a:hover{ background: #fff; color: #375794; }

ul.headerSns > li.footerBlog{ padding: 0; line-height: 1.5; margin-bottom: 10px; }
ul.headerSns > li.footerBlog a{ display: block; color: #fff; font-size: 1.4rem; text-align: center; background: #0068b7; border: 1px solid #0068b7; border-radius: 5px; padding: 10px; }
ul.headerSns > li.footerBlog a span{ display: block; margin-top: 2px; font-size: 1.2rem; }
ul.headerSns > li.footerBlog a:hover{ background: #fff; color: #0068b7; }

nav.l-drawer__menu > ul > li.home{ padding: 0; border-bottom: 1px solid #0068b7; line-height: 1; }
nav.l-drawer__menu > ul > li.home a{ display: block; color: #333; font-weight: bold; padding: .8em .9em 1em .9em; font-size: 1.7rem; }
nav.l-drawer__menu > ul > li:after{ display: none; }

.tabs input {
  position: absolute;
  opacity: 0;
  z-index: -1;
}

/* Accordion styles */
.tabs{ overflow: hidden; }
.tab{ width: 100%; color: #333; overflow: hidden; border-bottom: 1px solid #0068b7; }
.tab-label {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: justify;
          justify-content: space-between;
  padding: .6em .9em;
  font-weight: bold;
  cursor: pointer;
	font-size: 1.7rem;
  /* Icon */
}
.tab-label:hover {
}
.tab-label::after {
  content: "\276F";
  width: 1em;
  height: 1em;
  text-align: center;
  -webkit-transition: all .35s;
  transition: all .35s;
}
.tab-content {
  max-height: 0;
  padding: 0 1em;
  color: #0068b7;
  background: white;
  -webkit-transition: all .35s;
  transition: all .35s;
}
.tab-close {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: end;
          justify-content: flex-end;
  padding: 1em;
  font-size: 0.75em;
  background: #fff;
  cursor: pointer;
}
.tab-close:hover {
  background: #fff;
}

input:checked + .tab-label{ color: #fff; background: #0068b7; }
input:checked + .tab-label::after {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
input:checked ~ .tab-content {
  max-height: 100vh;
  padding: 0 1em;
}

.tab-content ul li{ position: relative; line-height: 1.8; border-bottom: 1px dotted #0068b7; }
.tab-content ul li:last-child{ border-bottom: none; }
.tab-content ul li a{ display: block; padding: 10px 10px 10px 30px; font-size: 1.6rem; }
.tab-content ul li:before{ position: absolute; display: block; top: 16px; left: 5px; font-family: 'icomoon'; content: "\e90e"; font-size: .9rem; color: #0068b7; font-weight: bold; }

.snsBtn{ margin-top: 30px; text-align: center; }
.snsBtn li{ margin-bottom: 10px; }
.snsBtn a{ display: block; color: #fff !important; background: #111; padding: 10px; text-align: center; line-height: 1.3; }
.snsBtn li i{ margin-right: 10px; }

.header_contact,
.header_tel{ display: none; }



/* ----------------------------------------------------------
 footer
---------------------------------------------------------- */
/* ページ下部 固定メニュー */
.btmMenu { position: fixed; bottom: -50px; width: 100%; border-top: 1px solid #0066b7; z-index: 99; }
.btmMenu li { float: left; width: 50%; }
.btmMenu li:first-child a { border-right: 1px solid #fff; }
.btmMenu li a { display: block; height: 29px; text-align: center; font-size: 1.6rem; padding: 15px 5px 5px; background-color: #0066b7; color: #fff; }
.btmMenu li a i{ font-size: 1.8rem; margin-right: 10px; }
.btmMenu li a:hover { background-color: #fff; color: #0066b7; }
.btmMenu ul:after { content: ''; clear: both; display: block; }

footer{
	background-image: url("../images/bg_footer_top01.png"),url("../images/bg_footer_bottom01.png");
	background-repeat: repeat-x,repeat-x;
	background-size: auto, auto;
	background-position: top,bottom;
	background-color: #000;
	padding: 90px 0 120px 0; }
#footer{ width: 100%; margin: 0 auto; }
.footerLogo{ text-align: center; margin: 0 auto 20px auto; }
.footerAdd{ color: #fff; font-size: 1.5rem; text-align: center; margin-bottom: 5px; }
.footerTel{ color: #fff; font-size: 1.5rem; text-align: center; margin-bottom: 20px; }
.footerSitemap{ display: none;  }


/* ----------------------------------------------------------
 hx
---------------------------------------------------------- */
.h1Wrap{ width: 96%; background-color: #111; line-height: 1; text-align: center; border: 3px solid #111; padding: 5px 8px; border-radius: 5px; position: absolute; top: 60px; left: 0; right: 0; margin: auto; }
h1{ font-size: 3rem; color: #fff; letter-spacing: 8px; text-align: center; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; display: flex; align-items: flex-end; justify-content: center; }
h1 p.h1p{ display: none; }
h1.blink-before::before { content: "\e909"; font-family: 'icomoon'; position: absolute; top: 7px; left: 1rem; font-size: 1.5rem; animation: none; }

.h2Wrap{ width: 96%; background-color: #111; line-height: 1; text-align: center; border: 3px solid #111; padding: 5px 8px; margin: 0 auto 40px auto; border-radius: 5px; }
.h201{ background: #111; border-top: 3px solid #fff; border-bottom: 3px solid #fff; }
.h202{ display: block; padding: 15px; margin: 0 -3px; background-image: url("../images/h2_bg03.png"),url("../images/h2_bg03.png"); background-position: left, right; background-repeat: no-repeat, no-repeat; }
h2{ font-size: 2rem; letter-spacing: 4px; }
.blink-before::before { top: 5px; left: 1rem; animation: blink 1.4s infinite; font-size: 1rem; }


.main h2{ font-size: 3.8rem; margin-bottom: 30px; }
.main h2 span{ font-size: 2rem; }

h3{ width: 100%; border-radius: 10px; padding: 5px; margin-bottom: 30px; background: #0068b7; }
h3 p{ font-size: 2.2rem; padding: 10px 10px 10px 50px; }
h3.blink-before::before{ color: #fff; top: 25px; left: 30px; }

h4{ font-size: 2rem; color: #333; letter-spacing: 3px; padding: 0 0 0 30px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; position: relative; margin-bottom: 20px; }
h4::before{ content: "\e909"; font-family: 'icomoon'; position: absolute; top: 0px; left: 0; color: #0068b7; font-size: 2rem; }

/* ぱんくず */
#breadcrumbs{ width: 1200px; margin: 0 auto; }  
#breadcrumbs ol{  } 
#breadcrumbs ol li{ display: inline-block; position: relative; }
#breadcrumbs ol li:before{ content: ">"; display: block; position: absolute; top: .5em; left: 0px; color: #333; font-size: 1.3rem; font-family: a-otf-ryumin-pr6n, serif; font-weight: 300; font-style: normal; }
#breadcrumbs ol li:first-child:before{ content: ""; }
#breadcrumbs ol li a{ color: #aaa; font-size: 1.3rem; margin: 0 0 0 13px; }
#breadcrumbs ol li:first-child a{ margin: 0 0 0 0; }
#breadcrumbs ol li a:hover{ opacity: 0.6; }
/* ----------------------------------------------------------
 contents
---------------------------------------------------------- */
.wrapper{ padding-top: 45px; }
.contents{ background: #fff; margin-top: 0px; padding-top: 130px; }
.main{ width: 90%; margin: 0 auto; }
.mainSecTxt{ font-size: 1.7rem; color: #333; text-align: center; line-height: 1.8; margin-bottom: 20px; }
.downArrow{ text-align: center; margin-bottom: 20px; }
.downArrow i{ margin: 0 3px; }


.topMovie{ width: 96%; padding: 20px 20px 10px 20px; }
.topMovieSec{ border-top: 8px solid #b1b1b1; border-right: 8px solid #b1b1b1; }

.topNews{ width: 100%; margin: 0 auto; background: url("../images/bg_news01.png") no-repeat top center; padding: 50px 0 30px 0; background-size: cover; }
.topNews01{ flex-basis: 100%; width: 90%; margin: 0 auto 30px auto; padding: 40px 20px 0 20px; }
.topNews01 ul{}
.topNews01 li{ flex-wrap: wrap; padding: 20px; border-bottom: 2px solid #bba076; }
.topNewsDate{ flex-basis: 100%; font-size: 1.4rem; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal; }
.topNewsDate i{ font-size: 1.2rem; margin-right: 10px; animation: flash2 1s linear infinite; }
.topNewsTxt01{ flex-basis: 100%; font-size: 1.5rem; }
	
.topNewsTit01{ flex-basis: 100%; font-size: 1.6rem; font-weight: 700; }

.top_column01{ flex-basis: 100%; padding: 0 20px 60px 20px; }



.ecBnr{ width: 90%; margin: 0 auto 40px auto; }
.ecBnr a:hover{ opacity: 0.6; }

.topTechnology{ background: url("../images/bg_technology01.jpg") no-repeat center top; background-size: cover; padding: 170px 0 80px 0; position: relative; }
.topTechnologyH2{ position: absolute; width: 96%; top: -50px; left: 0; right: 0; margin: auto; }
.topTechnology01{ width: 90%; margin: 0 auto; }
.topTechnology01 ul{ display: flex; justify-content: space-between; }
.topTechnology01 li{ flex-basis: 31%; text-align: center; }
.topTechnology01 li a{ display: block; width: 100%; height: 190px; position: relative; overflow: hidden; text-align: center; }
.topTechnology01 li a:before{ content: ""; display: block; position: absolute; width: 100%; height: 100%; top: 0; left: -100%; background: linear-gradient(30deg, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0) 75%);  }

.topTechnologyImg{ position: relative; }
.topTechnologyImgPress{ background-image:url("../images/tit_bg_press01.png"),url("../images/btn_press01.jpg"); background-repeat: no-repeat,no-repeat; background-position: bottom, top; background-size: contain, contain; }
.topTechnologyImgPlate{ background-image: url("../images/tit_bg_plate01.png"),url("../images/btn_plate01.jpg"); background-repeat: no-repeat,no-repeat; background-position: bottom, top; background-size: contain, contain; }
.topTechnologyImgSpinning{ background-image: url("../images/tit_bg_spinning01.png"), url("../images/btn_spinning01.jpg"); background-repeat: no-repeat, no-repeat; background-position: bottom, top; background-size: contain, contain; }
.topTechnologyTit01{ position: absolute; left: 0; right: 0; bottom: 7px; color: #fff; font-size: 1.4rem; margin: auto; text-align: center; }


.topProducts{ background: url("../images/bg_products01sp.jpg") repeat-y center top; background-size: cover; padding: 30px 0 40px 0; width: 100%; height: auto; }
.topProducts ul{ width: 90%; margin: 150px auto 0 auto; flex-wrap: wrap; }
.topProducts li{ flex-basis: 48%; text-align: center; background: url("../images/img_desk01.png") no-repeat center center; width: 286px; height: 236px; position: relative; margin-bottom: 100px; }
.topProducts li:nth-child(3),
.topProducts li:nth-child(4){ margin-bottom: 0; }

.topProductsSecImg{ position: absolute; top: -100px; left: 0; right: 0; margin: 0 auto; }
.topProductsSecImg img{ transition-duration: 0.5s; }
.topProductsSecImg:hover img{ transform: rotateY( 360deg ); transition-duration: 0.5s; }
.topProductsSecTit{ position: absolute; bottom: 55px; left: 0; right: 0; margin: 0 auto; color: #fff; font-size: 1.8rem; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; }


.topNav{ background: url("../images/bg_products01sp.jpg") center top; background-size: cover; padding: 50px 0 80px 0; width: 100%; height: auto; }
.topNav ul{ width: 90%; margin: 0 auto 0 auto; flex-wrap: wrap; }
.topNav li{ flex-basis: 48%; margin: 0; }
.topNav li:last-child{ flex-basis: 100%; margin: 10px 0 0 0; }
.topNavSecImg img{ transition: all 0.6s ease 0s; width: 100%; height: auto; }
.topNavSecImg:hover img{ transform: scale(1.1, 1.1); }


.topHaisou{ background: url("../images/bg_haisou01.png") repeat-x; margin-bottom: 0; }
.topHaisou{}

.demo_item{
	width: 200px;
    height: 153px;
    border-radius: 10px;
    background-image: url("../images/img_haisou01.png");
    background-size: 100% 100%;
    background-position: 0 0;
    background-repeat: no-repeat;
    display: block;
    position: relative;
    

}

.demo_stage{
    position: relative;
    width: 100%;
    height: 288px;
    top: 0px;
    display: block;
	background-image: url("../images/bg_haisou01.png");
	background-repeat: repeat-x;
	background-position: bottom;
}


.demo_wrap{
	display: block;
    position: absolute;
    top: 70px;
    animation-fill-mode: forwards;
    animation-timing-function: linear;
    animation-duration: 15s;
    animation-iteration-count: 1;
	margin-right: -25px;
}


.mapSec01{ padding-bottom: 40%; }



.technologySec{}
.technologySec > ul{ }
.technologySec > ul > li{ padding-bottom: 60px; background: url("../images/border_dash01.png") repeat-x left; background-position: bottom; margin-bottom: 60px; }
.technologySec > ul > li:last-child{ padding-bottom: 0; background: none; margin-bottom: 120px; }
.technologySec01 > ul > li:nth-child(1){ flex-basis: 100%; }
.technologySec01 > ul > li:nth-child(2){ flex-basis: 100%; }

.technologySec01 h3{ width: 300px; border-radius: 5px; padding: 5px; margin-bottom: 30px; }
.technologySec01 h3 p{ font-size: 2.2rem; padding: 8px; }
.technologySec01 h3.blink-before::before{ color: #fff; top: 25px; left: 30px; }
.technologySec01Btn{ width: 100%; margin-bottom: 10px; }

.footerContact{ position: relative; min-height: 243px; margin: 100px 0; }
.footerContactTit{ position: relative; background: url("../images/bg_contact01.png") no-repeat; background-size: contain; width: 100%; min-height: 60px; height: 60px; font-size: 2rem; padding: 18px 10px 15px 50px; }
.footerContactTit::before{ content: "\e909"; font-family: 'icomoon'; position: absolute; top: 22px; left: 25px; font-size: 1.2rem; animation: none; }
.footerContactTit span{ display: none; }
.footerContactSec{ position: relative; background: none; width: 100%; height: auto; padding: 20px; border: 3px solid #000; top: 0; }
.footerContactSecTit{ font-size: 1.6rem; margin-bottom: 20px; }
.footerContactSecTxt{ flex-wrap: wrap; }
.footerContactSecNum{ flex-basis: 100%; margin-bottom: 10px; }
.footerContactSecNum p{ flex-basis: 85%; font-size: 3.5rem; }
.footerContactSecNum i{ flex-basis: 35px; width: 35px; height: 35px; line-height: 35px; font-size: 1.8rem; }
.footerContactSecNum span{ flex-basis: 100%; display: block; font-size: 1.3rem; text-align: right; margin-right: 0; }
.footerContactSecBtn{ flex-basis: 100%; width: 100%; }
.footerContactSecBtn a{ display: block; font-size: 2.3rem; color: #fff; font-weight: 700; background: #111; padding: 15px; text-align: center; border: 3px solid #111; }
.footerContactSecBtn a i{ margin-right: 20px; }
.footerContactSecBtn a:hover{ background: #fff; color: #111; }


.mainNav{ width: 100%; margin: 0 auto 20px auto; }
.mainNav02{ width: 100%; margin: 0 auto 20px auto; }
.mainNav ul,
.mainNav02 ul{ flex-wrap: wrap; }
.mainNav li{ flex-basis: 48%; margin: 0 1% 10px 1%; }
.mainNav02 li{ flex-basis: 48%; margin: 0 auto 10px auto; }
.mainNav a,
.mainNav02 a{ font-size: 1.4rem; padding: 5px; }
.mainNav a i,
.mainNav02 a i{ margin-right: 5px; }



.productsSec{}

.productsSec h3{ width: 100%; border-radius: 5px; padding: 5px; margin-bottom: 30px; }
.productsSec h3 p{ font-size: 2.2rem; letter-spacing: 3px; border-radius: 5px; padding: 10px 10px 10px 50px; }
.productsSec h3.blink-before::before{ color: #fff; top: 25px; left: 30px; }

.productsSec > ul{}
.productsSec > ul > li,
.equipmentSec > ul > li,
.companySec > ul > li,
.contactSec > ul > li{ padding-bottom: 60px; background: url("../images/border_dash01.png") repeat-x left; background-position: bottom; margin-bottom: 60px; }
.productsSec > ul > li:last-child,
.equipmentSec > ul > li:last-child,
.companySec > ul > li:last-child,
.contactSec > ul > li:last-child{ padding-bottom: 0; background: none; margin-bottom: 120px; }


.productsSecTxt{ font-size: 1.7rem; line-height: 1.7; margin-bottom: 40px; }
.productsSec01{}
.productsSec01 > ul > li{ flex-basis: 100%; margin-bottom: 40px; }
.productsSec01Img{ margin-bottom: 10px; }
.productsSec01Img img{ width: 100%; height: auto; }
.productsSec01Tit{ font-size: 2rem; margin-bottom: 10px; }

.productsSec01Txt{ padding: 15px; font-size: 1.5rem; line-height: 1.7; background: url("../images/bg_txt01.png") no-repeat; width: 100%; height: 137px; background-size: 100% auto; }
.productsSec01Txt span{ font-weight: 700; }


.productsSecPress i{ color: #438943; margin-right: 10px; }
.productsSecHerashibori i{ color: #f15a24; margin-right: 10px; }
.productsSecBankin i{ color: #6c93cc; margin-right: 10px; }
.productsSecFukugou i{ color: #000; margin-right: 10px; }


.equipmentSec{}
.equipmentSecTxt{ font-size: 1.7rem; line-height: 1.7; margin-bottom: 60px; }


.movieSec > ul > li{ flex-basis: 100%; margin-bottom: 40px; }
.movieSec01{ position: relative; width: 100%; padding-top: 56.25%; }
.movieSec01 iframe{ position: absolute; top: 0; right: 0; width: 100%; height: 100%; }
.movieSecTxt{ font-size: 1.5rem; line-height: 1.7; }


.equipmentSec01{ width: 100%; margin: 0 auto 60px auto; }
.equipmentSec table{ display: block; overflow-x: scroll; white-space: nowrap; -webkit-overflow-scrolling: touch; }
.equipmentSec table th{ font-size: 1.5rem; }
.equipmentSec table th:nth-child(1),
.equipmentSec table th:nth-child(6){ width: 8%; }
.equipmentSec table th:nth-child(2),
.equipmentSec table th:nth-child(3),
.equipmentSec table th:nth-child(4),
.equipmentSec table th:nth-child(5){ width: 21%; }
.equipmentSec table td{ font-size: 1.5rem; }


.companySec{}

.greetingSec{}
.greetingSec > ul{ flex-wrap: wrap; }
.greetingSec > ul > li:nth-child(1){ flex-basis: 100%; }
.greetingSec > ul > li:nth-child(2){ flex-basis: 100%; text-align: center; }
.greetingSecTxt{}
.greetingSecTxt p{ font-size: 1.8rem; line-height: 1.8; margin-bottom: 30px; }
.greetingSec .footerContactTit{ margin: 0 auto; }
.greetingSec .footerContactTit span{ font-size: 1.8rem; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; letter-spacing: 4px; }
.greetingSec .mr20{ margin-right: 20px; }

.greetingSecImg{ text-align: center; }
.greetingSecImg img{ margin: 0 auto 20px auto; width: 80%; height: auto; }
.greetingSecName{ width: 90%; border-radius: 10px; padding: 5px; background: #111; margin: 0 auto; }
.greetingSecName p{ border: 3px solid #fff; color: #fff; font-size: 2.2rem; padding: 15px 10px 15px 40px; }
.greetingSecName span{ font-size: 1.6rem; margin-right: 10px; }
.greetingSecName.blink-before::before{ color: #fff; top: 32px; left: 30px; }


.profileSec,
.historySec{ width: 100%; margin: 0 auto 60px auto; }
.profileSec dl,
.historySec dl{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.profileSec dt,
.historySec dt{ flex-basis: 35%; padding: 15px 10px; font-size: 1.4rem; }
.profileSec dd,
.historySec dd{ flex-basis: 65%; padding: 15px 10px; font-size: 1.4rem; }

.profileSecImg{ width: 100%; margin-bottom: 80px; }
.profileSecImg > ul{ display: flex; justify-content: space-between; }
.profileSecImg > ul > li{ flex-basis: 49%; }
.profileSecImg > ul > li img{ width: 100%; height: auto; }

.accessSec{ width: 100%; margin: 0 auto 60px auto; position: relative; height: 0; padding-top: 56.25%; }
.accessSec iframe{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

.haisouSec{ width: 100%; margin: 0 auto 60px auto; }
.haisouSecTxt{ width: 100%; font-size: 1.6rem; line-height: 1.7; margin-bottom: 60px; }


.contactSec{ width: 100%; margin: 0 auto 60px auto; }
.attachedFileArea li{ margin-bottom: 10px !important; }

.privacySec p{ font-size: 1.6rem; line-height: 1.7; }
.privacySec p.mb20{ margin-bottom: 20px; }
.privacySecTxt{ margin-bottom: 40px; }
.privacySecTxt ol{ margin-left: 30px; margin-top: 10px; }
.privacySecTxt ol li{ list-style-type: decimal; font-size: 1.6rem; }

.thanksSec p{ margin-bottom: 20px; text-align: center; }
.thanksSec p.att{ color: #c00; font-weight: 700; }

.sitemapSec{ width: 980px; margin: 0 auto 60px auto; }
.sitemapSec ul{ }
.sitemapSec ul li{ font-size: 2.4rem; font-weight: 700; line-height: 1.9; }
.sitemapSec ul li i{ font-size: 1.8rem; margin-right: 5px; animation: flash2 1s linear infinite; }

.sitemapSec ul li a{  }
.sitemapSec ul li a:hover{ opacity: 0.6; }
.sitemapSec ul li ul{ margin: 5px 0 20px 70px; }
.sitemapSec ul li ul li{ font-size: 1.8rem; font-weight: 400; list-style-type: square; }
.sitemapSec ul li ul li a{ }

.sitemapSecTit{ display: flex; align-items: center; }
.sitemapIco{ width: 3%; margin-right: 10px; }
.sitemapIco img{ width: 100%; height: auto; vertical-align: middle; }
.sitemapSecTit p{}


/* 新設備導入 */
.sp_br{display: block;}
.trulaser_sec h2{font-size: 2.8rem; margin-bottom: 20px;}
.trulaser_main_txt{font-size: 1.4rem; line-height: 2.5rem;}
.trulaser_technology_list li{font-size: 1.8rem;}
.trulaser_material_sec{margin-bottom: 50px;}
.trulaser_material_table th, .trulaser_material_table td{font-size: 1.4rem;}
.trulaser_sample_list{flex-direction: column;}
.trulaser_sample_list li{width: 100%; max-width: 350px; margin: 0 auto;}

.trulaser_movie_inner{flex-direction: column; }
.trulaser_movie_item{width: 100%;}




}
/* ----------------------------------------------------------
 SP CSS END
---------------------------------------------------------- */

/* ----------------------------------------------------------
 TAB CSS
---------------------------------------------------------- */
@media screen and (min-width:681px) and (max-width:1024px){

img,video {
  max-width: 100%;
  height: auto;
}

/* フォントサイズ10px=62.5% */
html{ font-size: 50%; }

/* 基本のフォントサイズ */
body{ font-size: 1.8rem; background-image: none; padding-top: 0; }

/* 非表示用 */
.noneTAB		{ display: none !important; }
/* ----------------------------------------------------------
 link
---------------------------------------------------------- */
/* ----------------------------------------------------------
 header
---------------------------------------------------------- */
header{ height: 57px; top: 0; left: 0; z-index: 999; }
#header{ width: 100%; background: #fff;}
.headerLogo{ flex-basis: 50%; text-align: left; padding: 10px; }
.headerLogo img{ width: 60%; margin: 0 auto; }
.headerLogo a:hover{ opacity: 0.6; }
#gNavi{ flex-basis: 40%; margin-right: 55px; }

.mega-menu{ display: flex; align-items: center; }
.mega-menu > li{ flex-basis: 25%; border-right: 3px solid #ddd; text-align: center; }
.mega-menu > li:first-child{ border-left: 3px solid #ddd; }
.mega-menu > li > a{ display: block; min-height: 30px; padding: 10px 3px 5px 3px; }
.mega-menu li .gNavi01{ display: flex; justify-content: space-between; }
.mega-menu li .gNavi01Ico{ flex-basis: 100%; text-align: center; }
.mega-menu li .gNavi01Tit{ display: none; }
.mega-menu li i{ display: none; }


.mega-menu li:hover > a,
.mega-menu li > a.current{ background: #0068b7; color: #fff; }
.mega-menu li:hover .gNavi01Tit{ color: #fff; }
.mega-menu li:hover i{ color: #fff; animation: none; }


/***********
 ドロップダウン
************/
.drop {
     display: none; border: 0; background: none;
}
.drop ul{ display: none; }

/*ドロワー*/
.l-drawer{ position: relative; }
.l-drawer__checkbox{ display: none; }
.l-drawer__icon{
	cursor: pointer;
	display: block;
	width: 50px;
	height: 50px;
	position: fixed;
	top: 5px;
	right: 3px;
}
.l-drawer__icon-parts, .l-drawer__icon-parts:before, .l-drawer__icon-parts:after{
	background-color: #0068b7;
	display: block;
	width: 26px;
	height: 2px;
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	margin: auto;
}
.l-drawer__icon-parts:before, .l-drawer__icon-parts:after{ content: " "; }
.l-drawer__icon-parts:before{ transform: translateY(9px); }
.l-drawer__icon-parts:after{ transform: translateY(-9px); }
.l-drawer__overlay{
	background: #000;
	opacity: 0;
	pointer-events: none;
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	right: 0;
}
.l-drawer__menu{
	background: rgba(255,255,255,0.9);
	color: #000;
	max-width: 100%;
	width: 100vw;
	height: 100vh;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	position: fixed;
	top: 0;
	right: -100vw;
}
.l-drawer__icon{ z-index: 999; }
.l-drawer__menu{ z-index: 998; }
.l-drawer__overlay{ z-index: 99; }
.l-drawer__checkbox:checked ~ .l-drawer__icon .l-drawer__icon-parts{ background: transparent; }
.l-drawer__checkbox:checked ~ .l-drawer__icon .l-drawer__icon-parts:before{ -webkit-transform: rotate(-45deg); transform: rotate(-45deg); top: 0; }
.l-drawer__checkbox:checked ~ .l-drawer__icon .l-drawer__icon-parts:after{ -webkit-transform: rotate(45deg); transform: rotate(45deg); top: 0; }
.l-drawer__checkbox:checked ~ .l-drawer__overlay{ opacity: 0.3; pointer-events: auto; }
.l-drawer__checkbox:checked ~ .l-drawer__menu{ right: 0; }
.l-drawer__icon-parts, .l-drawer__icon-parts:after, .l-drawer__icon-parts:before, .l-drawer__overlay, .l-drawer__menu{ -webkit-transition: all 0.7s; transition: all 0.7s; }

nav.l-drawer__menu{ padding: 80px 30px 80px 30px; }
nav.l-drawer__menu > ul > li{ display: block; color: #333; padding: 0 10px 0 20px; position: relative; font-size: 2.2rem; line-height: 3em; letter-spacing: 1px; }
nav.l-drawer__menu > ul > li a{ color: #333; }
nav.l-drawer__menu > ul > li a:hover{ opacity: 0.6; }
nav.l-drawer__menu > ul > li:after{ position: absolute; content: ""; display: block; top: 1.1em; left: 0; width: 10px; height: 10px; background-color: #86c02e; border-radius: 100%; }
nav.l-drawer__menu > ul > li > ul{ margin: 0 0 10px 20px; }
nav.l-drawer__menu > ul > li > ul > li{ font-size: 1.8rem; line-height: 1.8em; }
nav.l-drawer__menu > ul > li > ul > li:before{ font-family: 'icomoon'; content: "\e90e"; font-size: 1rem; color: #86c02e; font-weight: bold; margin-right: 5px; }



ul.headerSns{ width: 100%; margin-top: 10px; }
ul.headerSns li:after{ display: none !important; }
ul.headerSns > li.footerYoutube{ padding: 0; line-height: 1.5; margin-bottom: 10px; }
ul.headerSns > li.footerYoutube a{ display: block; color: #fff; font-size: 1.8rem; text-align: center; background: #f8031b; border: 1px solid #f8031b; border-radius: 5px; padding: 10px; }
ul.headerSns > li.footerYoutube a i{ margin-right: 5px; }
ul.headerSns > li.footerYoutube a:hover{ background: #fff; color: #f8031b; }
ul.headerSns > li.footerFacebook{ padding: 0; line-height: 1.5; margin-bottom: 10px; }
ul.headerSns > li.footerFacebook a{ display: block; color: #fff; font-size: 1.8rem; text-align: center; background: #375794; border: 1px solid #375794; border-radius: 5px; padding: 10px; }
ul.headerSns > li.footerFacebook a i{ margin-right: 5px; }
ul.headerSns > li.footerFacebook a:hover{ background: #fff; color: #375794; }

ul.headerSns > li.footerBlog{ padding: 0; line-height: 1.5; margin-bottom: 10px; }
ul.headerSns > li.footerBlog a{ display: block; color: #fff; font-size: 1.4rem; text-align: center; background: #0068b7; border: 1px solid #0068b7; border-radius: 5px; padding: 10px; }
ul.headerSns > li.footerBlog a span{ display: block; margin-top: 2px; font-size: 1.2rem; }
ul.headerSns > li.footerBlog a:hover{ background: #fff; color: #0068b7; }

nav.l-drawer__menu > ul > li.home{ padding: 0; border-bottom: 1px solid #0068b7; line-height: 1; }
nav.l-drawer__menu > ul > li.home a{ display: block; color: #333; font-weight: bold; padding: .8em .9em 1em .9em; font-size: 1.7rem; }
nav.l-drawer__menu > ul > li:after{ display: none; }

.tabs input {
  position: absolute;
  opacity: 0;
  z-index: -1;
}

/* Accordion styles */
.tabs{ overflow: hidden; }
.tab{ width: 100%; color: #333; overflow: hidden; border-bottom: 1px solid #0068b7; }
.tab-label {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: justify;
          justify-content: space-between;
  padding: .6em .9em;
  font-weight: bold;
  cursor: pointer;
	font-size: 1.7rem;
  /* Icon */
}
.tab-label:hover {
}
.tab-label::after {
  content: "\276F";
  width: 1em;
  height: 1em;
  text-align: center;
  -webkit-transition: all .35s;
  transition: all .35s;
}
.tab-content {
  max-height: 0;
  padding: 0 1em;
  color: #0068b7;
  background: white;
  -webkit-transition: all .35s;
  transition: all .35s;
}
.tab-close {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: end;
          justify-content: flex-end;
  padding: 1em;
  font-size: 0.75em;
  background: #fff;
  cursor: pointer;
}
.tab-close:hover {
  background: #fff;
}

input:checked + .tab-label{ color: #fff; background: #0068b7; }
input:checked + .tab-label::after {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
input:checked ~ .tab-content {
  max-height: 100vh;
  padding: 0 1em;
}

.tab-content ul li{ position: relative; line-height: 1.8; border-bottom: 1px dotted #0068b7; }
.tab-content ul li:last-child{ border-bottom: none; }
.tab-content ul li a{ display: block; padding: 10px 10px 10px 30px; font-size: 1.6rem; }
.tab-content ul li:before{ position: absolute; display: block; top: 16px; left: 5px; font-family: 'icomoon'; content: "\e90e"; font-size: .9rem; color: #0068b7; font-weight: bold; }

.snsBtn{ text-align: center; width: 80%; margin: 30px auto 0 auto; display: flex; justify-content: space-between; }
.snsBtn li{ flex-basis: 48%; }
.snsBtn a{ display: block; color: #fff !important; background: #111; padding: 10px; text-align: center; line-height: 1.3; }
.snsBtn li i{ margin-right: 10px; }

.header_contact,
.header_tel{ display: none; }

/* ----------------------------------------------------------
 footer
---------------------------------------------------------- */
/* ページ下部 固定メニュー */
.btmMenu { display: none; }

footer{
	background-image: url("../images/bg_footer_top01.png"),url("../images/bg_footer_bottom01.png");
	background-repeat: repeat-x,repeat-x;
	background-size: auto, auto;
	background-position: top,bottom;
	background-color: #000;
	padding: 90px 0 120px 0; }
#footer{ width: 100%; margin: 0 auto; }
.footerLogo{ text-align: center; margin: 0 auto 20px auto; }
.footerAdd{ color: #fff; font-size: 1.5rem; text-align: center; margin-bottom: 5px; }
.footerTel{ color: #fff; font-size: 1.5rem; text-align: center; margin-bottom: 20px; }
.footerSitemap{ display: none; }


/* ----------------------------------------------------------
 hx
---------------------------------------------------------- */
.h1Wrap{ width: 96%; background-color: #111; line-height: 1; text-align: center; border: 3px solid #111; padding: 5px 8px; border-radius: 5px; position: absolute; top: 70px; left: 0; right: 0; margin: auto; }
h1{ font-size: 3rem; color: #fff; letter-spacing: 8px; text-align: center; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; display: flex; align-items: flex-end; justify-content: center; }
h1 p.h1p{ display: none; }
h1.blink-before::before { content: "\e909"; font-family: 'icomoon'; position: absolute; top: 7px; left: 1rem; font-size: 1.5rem; animation: none; }

.h2Wrap{ width: 500px; background-color: #111; line-height: 1; text-align: center; border: 3px solid #111; padding: 5px 8px; margin: 0 auto 40px auto; border-radius: 5px; }
.h201{ background: #111; border-top: 3px solid #fff; border-bottom: 3px solid #fff; }
.h202{ display: block; padding: 15px; margin: 0 -3px; background-image: url("../images/h2_bg03.png"),url("../images/h2_bg03.png"); background-position: left, right; background-repeat: no-repeat, no-repeat; }
h2{ font-size: 2rem; letter-spacing: 4px; }
.blink-before::before { top: 5px; left: 1rem; animation: blink 1.4s infinite; font-size: 1rem; }


.main h2{ font-size: 5.5rem; color: #0066b7; text-align: center; letter-spacing: 5px; font-weight: 700; margin-bottom: 30px; }
.main h2 span{ display: block; font-size: 2.5rem; color: #111; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal;letter-spacing: 2px; }

h3{ width: 400px; border-radius: 10px; padding: 5px; margin-bottom: 30px; background: #0068b7; }
h3 p{ font-size: 2.5rem; padding: 10px 18px 10px 50px; }
h3.blink-before::before{ color: #fff; top: 25px; left: 30px; }

h4{ font-size: 2.3rem; color: #333; letter-spacing: 3px; padding: 0 0 0 30px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; position: relative; margin-bottom: 20px; }
h4::before{ content: "\e909"; font-family: 'icomoon'; position: absolute; top: 0px; left: 0; color: #0068b7; font-size: 2rem; }

/* ぱんくず */
#breadcrumbs{ display: none; }

/* ----------------------------------------------------------
 contents
---------------------------------------------------------- */
.wrapper{ padding-top: 60px; }
.contents{ background: #fff; margin-top: 40px; padding-top: 80px; }
.main{ width: 96%; margin: 0 auto; }
.mainSecTxt{ font-size: 1.7rem; color: #333; text-align: center; line-height: 1.8; margin-bottom: 40px; }
.downArrow{ text-align: center; margin-bottom: 40px; }
.downArrow i{ margin: 0 3px; }


.topMovie{ width: 100%; margin: 0 auto; background: #ddd; border-radius: 15px; padding: 40px 40px 20px 40px; box-shadow: 2.5rem 2.5rem 2rem -2rem hsl(200 50% 20% / 40%); }
.topMovieSec{ border-top: 8px solid #b1b1b1; border-right: 8px solid #b1b1b1; }
.topMovieSec01{ position: relative; width: 100%; padding-top: 56.25%; }
.topMovieSec01 iframe{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.topMovie ul{ display: flex; justify-content: space-between; margin-top: 10px; }
.topMovie li{ font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal; font-size: 1.4rem; position: relative; padding-left: 25px; }
.topMovie li:before{ display: block; content: ""; position: absolute; left: 0; top: 1px; width: 8px; height: 8px; border-radius: 100%; background: #d9d900; border: 4px solid #d9a300;  }

/*
.topNews{ width: 100%; margin: 0 auto; background: url("../images/bg_news01.png") no-repeat top center; padding: 100px 0 30px 0; }
.topNews01{ width: 90%; margin: 0 auto 80px auto; }
.topNews01 ul{}
.topNews01 li{ display: flex; justify-content: space-between; padding: 20px; border-bottom: 2px solid #bba076; }
.topNewsDate{ flex-basis: 20%; font-size: 1.4rem; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal; }
.topNewsDate i{ font-size: 1.2rem; margin-right: 10px; animation: flash2 1s linear infinite; }
.topNewsTxt01{ flex-basis: 80%; font-size: 1.5rem; }
*/

.topNews{ width: 100%; margin: 0 auto; background: url("../images/bg_news01.png") no-repeat top center; padding: 50px 0 30px 0; background-size: cover; }
.topNews01{ flex-basis: 100%; width: 90%; margin: 0 auto 30px auto; padding: 40px 20px 0 20px; }
.topNews01 ul{}
.topNews01 li{ flex-wrap: wrap; padding: 20px; border-bottom: 2px solid #bba076; }
.topNewsDate{ flex-basis: 100%; font-size: 1.4rem; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal; }
.topNewsDate i{ font-size: 1.2rem; margin-right: 10px; animation: flash2 1s linear infinite; }
.topNewsTxt01{ flex-basis: 100%; font-size: 1.5rem; }
	
.topNewsTit01{ flex-basis: 100%; font-size: 1.6rem; font-weight: 700; }

.top_column01{ flex-basis: 100%; padding: 0 20px 60px 20px; }



.topTechnology{ background: url("../images/bg_technology01.jpg") no-repeat center top; background-size: cover; padding: 100px 0 80px 0; position: relative; }
.topTechnologyH2{ position: absolute; width: 500px; top: -50px; left: 0; right: 0; margin: auto; }
.topTechnology01{ width: 90%; margin: 0 auto; }
.topTechnology01 ul{ display: flex; justify-content: space-between; }
.topTechnology01 li{ flex-basis: 30%; text-align: center; }
.topTechnology01 li a{ display: block; width: 100%; min-width: 30%; height: auto; min-height: 370px; position: relative; overflow: hidden; }
.topTechnology01 li a:before{ content: ""; display: block; position: absolute; width: 100%; height: 100%; top: 0; left: -100%; background: linear-gradient(30deg, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0) 75%);  }
.topTechnology01 li a:hover:before{ animation: shine .3s ease-in-out; }

.topTechnologyImg{ position: relative; }
.topTechnologyImgPress{ background-size: 100% auto; }
.topTechnologyImgPlate{ background-size: 100% auto; }
.topTechnologyImgSpinning{ background-size: 100% auto; }
.topTechnologyTit01{ left: 0; right: 0; margin: 0 auto; bottom: 20px; font-size: 2rem; }


.topProducts{ background: url("../images/bg_products01sp.jpg") repeat center top; background-size: contain; padding: 50px 0 30px 0; width: 100%; height: auto; }
.topProducts ul{ width: 90%; margin: 200px auto 0 auto; flex-wrap: wrap; }
.topProducts li{ flex-basis: 48%; text-align: center; background: url("../images/img_desk01.png") no-repeat center center; width: 286px; height: 236px; position: relative; margin-bottom: 100px; }
.topProducts li:nth-child(3),
.topProducts li:nth-child(4){ margin-bottom: 0; }

.topProductsSecImg{ position: absolute; top: -100px; left: 0; right: 0; margin: 0 auto; }
.topProductsSecImg img{ transition-duration: 0.5s; }
.topProductsSecImg:hover img{ transform: rotateY( 360deg ); transition-duration: 0.5s; }
.topProductsSecTit{ position: absolute; bottom: 55px; left: 0; right: 0; margin: 0 auto; font-size: 2rem; }


.topNav{ background: url("../images/bg_products01.jpg") no-repeat center bottom; background-size: cover; padding: 50px 0 30px 0; width: 100%; height: auto; }
.topNav ul{ width: 90%; margin: 20px auto 0 auto; display: flex; justify-content: center; align-items: flex-end; }
.topNav li{ flex-basis: 32%; margin: 0; }
.topNavSecImg img{ transition: all 0.6s ease 0s; width: 100%; height: auto; }
.topNavSecImg:hover img{ transform: scale(1.1, 1.1); }
.topNav li:first-child img{ width: 80%; height: auto; }


.topHaisou{ background: url("../images/bg_haisou01.png") repeat-x; margin-bottom: 0; }
.topHaisou{}

.demo_item{
	width: 200px;
    height: 153px;
    border-radius: 10px;
    background-image: url("../images/img_haisou01.png");
    background-size: 100% 100%;
    background-position: 0 0;
    background-repeat: no-repeat;
    display: block;
    position: relative;
    

}

.demo_stage{
    position: relative;
    width: 100%;
    height: 288px;
    top: 0px;
    display: block;
	background-image: url("../images/bg_haisou01.png");
	background-repeat: repeat-x;
	background-position: bottom;
}


.demo_wrap{
	display: block;
    position: absolute;
    top: 70px;
    animation-fill-mode: forwards;
    animation-timing-function: linear;
    animation-duration: 15s;
    animation-iteration-count: 1;
	margin-right: -25px;
}


.mapSec01{ padding-bottom: 40%; }



.technologySec{}
.technologySec > ul{ }
.technologySec > ul > li{ padding-bottom: 120px; background: url("../images/border_dash01.png") repeat-x left; background-position: bottom; margin-bottom: 120px; }
.technologySec > ul > li:last-child{ padding-bottom: 0; background: none; margin-bottom: 120px; }
.technologySec01 > ul{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.technologySec01 > ul > li{}
.technologySec01 > ul > li:nth-child(1){ flex-basis: 38%; }
.technologySec01 > ul > li:nth-child(2){ flex-basis: 55%; }
.technologySec01{}
.technologySec01 h3{ width: 300px; border-radius: 5px; padding: 5px; margin-bottom: 30px; }
.technologySec01 h3 p{ font-size: 2.5rem; padding: 15px; }
.technologySec01 h3.blink-before::before{ color: #fff; top: 35px; left: 30px; }
.technologySec01Txt{}
.technologySec01Txt01{ font-size: 1.7rem; line-height: 1.7; margin-bottom: 30px; }
.technologySec01Btn{ width: 250px; margin-bottom: 20px; }
.technologySec01Btn a{ display: block; font-size: 1.8rem; font-weight: 700; text-align: center; padding: 10px; border: 2px solid; letter-spacing: 2px; }
.technologySec01Btn a i{ margin-right: 10px; font-size: 1.5rem; }
.technologySec01Btn a:hover{ color: #fff !important; }

.technologySec01Img{}
.technologySec01Img > ul{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.technologySec01Img > ul > li{}
.technologySec01Img > ul > li img{ width: 100%; height: auto; }
.technologySec01Img > ul > li:nth-child(1){ flex-basis: 100%; margin-bottom: 10px; }
.technologySec01Img > ul > li:nth-child(2),
.technologySec01Img > ul > li:nth-child(3){ flex-basis: 49%; }



.footerContact{ position: relative; min-height: auto; margin: 100px 0; }
.footerContactTit{ position: relative; background: url("../images/bg_contact01.png") no-repeat; width: 410px; height: 70px; font-size: 2.5rem; letter-spacing: 3px; color: #fff; padding: 18px 10px 15px 50px; }
.footerContactTit::before{ content: "\e909"; font-family: 'icomoon'; position: absolute; top: 23px; left: 25px; font-size: 1.5rem; animation: none; }
.footerContactTit span{ color: #fff; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal; font-size: 1.3rem; letter-spacing: 2px; font-weight: normal; margin-left: 20px; }
.footerContactSec{ position: relative; top: 0; right: 0; background: none; border: 3px solid; width: 100%; height: auto; padding: 20px; background-size: contain; }
.footerContactSecTit{ font-size: 2rem; color: #666; letter-spacing: 1px; font-weight: 700; margin-bottom: 20px; }
.footerContactSecTxt{ display: flex; justify-content: space-between; }
.footerContactSecNum{ flex-basis: 60%; display: flex; justify-content: space-between; flex-wrap: wrap; align-items: center; }
.footerContactSecNum p{ flex-basis: 85%; font-size: 5rem; color: #0066b7; font-family: poster-gothic-excond-atf, sans-serif; font-weight: 700; font-style: normal; line-height: 1; }
.footerContactSecNum i{ flex-basis: 50px; display: block; width: 50px; height: 50px; text-align: center; line-height: 50px; background: #0066b7; color: #fff; font-size: 2rem; }
.footerContactSecNum span{ flex-basis: 100%; display: block; font-size: 1.6rem; color: #666; font-family: source-han-sans-japanese, sans-serif; font-weight: 700; font-style: normal; text-align: right; margin-right: 80px; }
.footerContactSecBtn{ flex-basis: 40%; width: 400px; }
.footerContactSecBtn a{ display: block; font-size: 2.3rem; color: #fff; font-weight: 700; background: #111; padding: 15px; text-align: center; border: 3px solid #111; }
.footerContactSecBtn a i{ margin-right: 20px; }
.footerContactSecBtn a:hover{ background: #fff; color: #111; }

.mainNav{ width: 100%; margin: 0 auto 40px auto; }
.mainNav02{ width: 100%; margin: 0 auto 40px auto; }
.mainNav ul,
.mainNav02 ul{ flex-wrap: wrap; }
.mainNav li{ flex-basis: 24%; margin: 0 .5%; }
.mainNav02 li{ flex-basis: 31%; margin: 0 1%; }
.mainNav a,
.mainNav02 a{ display: block; color: #0068b7; font-size: 1.6rem; font-weight: 700; letter-spacing: 2px; padding: 5px 20px; border: 3px solid #0068b7; }


.productsSec{}

.productsSec h3{ width: 400px; border-radius: 5px; padding: 5px; margin-bottom: 30px; }
.productsSec h3 p{ border: 3px solid #fff; color: #fff; font-size: 2.5rem; letter-spacing: 3px; border-radius: 5px; padding: 10px 20px 10px 50px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; }
.productsSec h3.blink-before::before{ color: #fff; top: 25px; left: 30px; }

.productsSec > ul{}
.productsSec > ul > li,
.equipmentSec > ul > li,
.companySec > ul > li,
.contactSec > ul > li{ padding-bottom: 120px; background: url("../images/border_dash01.png") repeat-x left; background-position: bottom; margin-bottom: 120px; }
.productsSec > ul > li:last-child,
.equipmentSec > ul > li:last-child,
.companySec > ul > li:last-child,
.contactSec > ul > li:last-child{ padding-bottom: 0; background: none; margin-bottom: 120px; }


.productsSecTxt{ font-size: 1.7rem; line-height: 1.7; margin-bottom: 40px; }
.productsSec01{}
.productsSec01 > ul{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.productsSec01 > ul > li{ flex-basis: 48%; margin-bottom: 40px; }
.productsSec01Img{ margin-bottom: 10px; }
.productsSec01Img img{ width: 100%; height: auto; }
.productsSec01Tit{ font-size: 2rem; color: #535353; letter-spacing: 2px; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; margin-bottom: 10px; }

.productsSec01Txt{ padding: 20px; font-size: 1.5rem; line-height: 1.7; background: url("../images/bg_txt01.png") no-repeat; width: 100%; height: auto; background-size: 100% auto; min-height: 160px; }
.productsSec01Txt span{ font-weight: 700; }


.productsSecPress i{ color: #438943; margin-right: 10px; }
.productsSecHerashibori i{ color: #f15a24; margin-right: 10px; }
.productsSecBankin i{ color: #6c93cc; margin-right: 10px; }
.productsSecFukugou i{ color: #000; margin-right: 10px; }


.equipmentSec{}
.equipmentSecTxt{ font-size: 1.7rem; line-height: 1.7; margin-bottom: 60px; }


.movieSec{}
.movieSec > ul{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.movieSec > ul > li{ flex-basis: 49%; margin-bottom: 40px; }
.movieSec01{ position: relative; width: 100%; padding-top: 56.25%; }
.movieSec01 iframe{ position: absolute; top: 0; right: 0; width: 100%; height: 100%; }
.movieSecTxt{ font-size: 1.7rem; line-height: 1.7; }


.equipmentSec01{ width: 100%; margin: 0 auto 60px auto; }
.equipmentSec table{ display: block; overflow-x: scroll; white-space: nowrap; -webkit-overflow-scrolling: touch; }


.companySec{}

.greetingSec{}
.greetingSec > ul{ flex-wrap: wrap; }
.greetingSec > ul > li:nth-child(1){ flex-basis: 80%; margin: 0 10% 20px 10%; }
.greetingSec > ul > li:nth-child(2){ flex-basis: 100%; text-align: center; }
.greetingSecTxt{}
.greetingSecTxt p{ font-size: 1.8rem; line-height: 1.8; margin-bottom: 30px; }
.greetingSec .footerContactTit{ margin: 0 auto; }
.greetingSec .footerContactTit span{ font-size: 1.8rem; font-family: ryo-gothic-plusn, sans-serif; font-weight: 800; font-style: normal; letter-spacing: 4px; }
.greetingSec .mr20{ margin-right: 20px; }

.greetingSecImg{ text-align: center; width: 50%; margin: 0 auto; }
.greetingSecImg img{ margin-bottom: 20px; width: 100%; height: auto; }
.greetingSecName{ width: 50%; border-radius: 10px; padding: 5px; background: #111; margin: 0 auto;  }
.greetingSecName p{ border: 3px solid #fff; color: #fff; font-size: 2.5rem; letter-spacing: 3px; border-radius: 10px; padding: 10px 15px 10px 45px; }
.greetingSecName span{ font-size: 1.8rem; margin-right: 0; display: block; }
.greetingSecName.blink-before::before{ color: #fff; top: 32px; left: 30px; }


.profileSec,
.historySec{ width: 100%; margin: 0 auto 60px auto; }
.profileSec dl,
.historySec dl{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.profileSec dt,
.historySec dt{ flex-basis: 20%; padding: 15px; border-bottom: 1px solid #ccc; text-align: center; font-weight: 500; }
.profileSec dd,
.historySec dd{ flex-basis: 80%; padding: 15px; border-bottom: 1px solid #ccc; }

.profileSecImg{ width: 100%; margin-bottom: 80px; }
.profileSecImg > ul{ display: flex; justify-content: space-between; }
.profileSecImg > ul > li{ flex-basis: 49%; }
.profileSecImg > ul > li img{ width: 100%; height: auto; }

.accessSec{ width: 100%; margin: 0 auto 60px auto; position: relative; height: 0; padding-top: 56.25%; }
.accessSec iframe{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

.haisouSec{ width: 100%; margin: 0 auto 60px auto; }
.haisouSecTxt{ width: 100%; font-size: 1.6rem; line-height: 1.7; margin-bottom: 60px; }


.contactSec{ width: 90%; margin: 0 auto 60px auto; }
.attachedFileArea li{ margin-bottom: 10px !important; }

.privacySec p{ font-size: 1.6rem; line-height: 1.7; }
.privacySec p.mb20{ margin-bottom: 20px; }
.privacySecTxt{ margin-bottom: 40px; }
.privacySecTxt ol{ margin-left: 30px; margin-top: 10px; }
.privacySecTxt ol li{ list-style-type: decimal; font-size: 1.6rem; }

.thanksSec p{ margin-bottom: 20px; text-align: center; }
.thanksSec p.att{ color: #c00; font-weight: 700; }

.sitemapSec{ width: 80%; margin: 0 auto 60px auto; }

/* 新設備導入 */
.trulaser_sample_list{gap: 25px;}
.trulaser_sample_list li{width: calc((100% - 50px)/3);}

.trulaser_movie_sec{gap: 30px;}
.trulaser_movie_item{width: calc((100% - 30px)/2);}


}
/* ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 TAB CSS END
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ */

/* ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 PC CSS
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ */
@media print, screen and (min-width:1025px) and (max-width:1419px){

/* フォントサイズ10px */
html{ font-size: 62.5%; }

/* 基本のフォントサイズ */
body{ font-size: 16px; font-size: 1.8rem; }

/* 非表示用 */
.nonePC		{ display: none !important; }
/* ----------------------------------------------------------
 link
---------------------------------------------------------- */
/* ----------------------------------------------------------
 header
---------------------------------------------------------- */
#header{width: 100%;}
.icon{ display: none; }
.mega-menu li .gNavi01Tit{font-size: 1.4rem;}


/* ----------------------------------------------------------
 footer
---------------------------------------------------------- */
.footerContact{margin: 130px 0;}
.footerContactSec{position: relative; top: initial; background: none; width: 90%; max-width: 1100px; margin: 0 auto; border: 3px solid;}
.footerContactTit{top: -65px;}


.btmMenu { display: none; }
#footer{width: 100%;}
.footerSitemap{gap: 20px;}
.footerSitemap ul{margin: 0;}

/* ----------------------------------------------------------
 hx
---------------------------------------------------------- */



/* ----------------------------------------------------------
 contents
---------------------------------------------------------- */
.trulaser_sec h2 span{display: none;}
.main{width: 100%;}
.trulaser_sec{width: 90%;}



}
/* ----------------------------------------------------------
 PC CSS END
---------------------------------------------------------- */
/* ----------------------------------------------------------
 PC WIDE CSS
---------------------------------------------------------- */
@media screen and (min-width:1420px){
/* フォントサイズ10px */
html{ font-size: 62.5%; height: 100%; }

/* 基本のフォントサイズ */
body{ font-size: 16px; font-size: 1.8rem; height: 100%; }

/* 非表示用 */
.nonePCWIDE		{ display: none !important; }

/* ----------------------------------------------------------
 link
---------------------------------------------------------- */
/* ----------------------------------------------------------
 header
---------------------------------------------------------- */
.icon{ display: none; }

/* ----------------------------------------------------------
 footer
---------------------------------------------------------- */
/* ページ下部 固定メニュー */
.btmMenu { display: none; }



/* ----------------------------------------------------------
 hx
---------------------------------------------------------- */



/* ----------------------------------------------------------
 contents
---------------------------------------------------------- */
.trulaser_sec h2 span{display: none;}




}
/* ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 PCWIDE CSS END
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ */
