/*
Theme Name: hokuto
*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900');
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fredericka+the+Great&display=swap');

*{ margin:0; padding:0; outline:none;}
body{ margin:0; padding:0; box-sizing:border-box; -ms-word-wrap:break-word; word-wrap:break-word; line-height:28px;}
img{ margin:0; padding:0; border:none; max-width:100%;}
section img, img{max-width:100%; height:auto;}
h1,h2,h3,h4,h5,h6{ margin:0 0 20px; padding:0; line-height:1; font-weight:400; }
h1{ font-size:36px;}
h2{ font-size:30px;}
h3{ font-size:18px;}
h4{ font-size:22px;}
h5{ font-size:20px;}
h6{ font-size:14px;}
.left{float:left;}
.right{float:right;}
blockquote{ background:url(images/icon_quote.png) no-repeat 20px 22px; padding:15px 15px 15px 60px !important; font-style:italic; color:#888; font-size:14px; line-height:1.5;}
.hr{border-bottom:1px solid #333; height:15px; clear:both;}
p{ margin:0 0 20px 0; padding:0; line-height:28px;}
p:empty{ margin:0 !important; line-height:0 !important; display:none !important}
a{ text-decoration:none; outline:none;}
a:hover{ text-decoration:none; outline:none;}
ul{ list-style:none; margin:0;}
ol, ul {
    box-sizing: border-box;
    padding: 8px 20px;
}
/* article ul, article ol{ margin:0 0 15px 15px;} */
article ul li{ list-style: disc;}
.flow ul li {list-style: none;}
.custom-height{ min-height:20px;}
.clear{ clear:both;}
.middle-align{ margin:0 auto; padding:0;}
.wp-caption{ margin:0; padding:0; font-size:13px; max-width:100% !important;}
.wp-caption-text{ margin:0; padding:0;}
.sticky{ margin:0; padding:0;}
.gallery-caption{ margin:0; padding:0;}
.alignleft, img.alignleft {display: inline; float: left; margin-right:25px; margin-top:4px; margin-bottom:6px; padding:0; height:auto;}
.alignright, img.alignright { display: inline; float: right; margin-left:25px; height:auto;}
.aligncenter, img.aligncenter { clear: both; display: block; margin-left: auto; margin-right: auto; margin-top:0;  height:auto;}
.comments-area{ margin-bottom:15px;}
.comment-list .comment-content ul { list-style:none; margin-left:15px;}
.comment-list .comment-content ul li{margin:5px;}
.main-container ol{list-style-position:outside; margin-left:20px;}
.main-container ol li{margin:5px 0;}
.lastcols{ margin-right:0 !important;}
.toggleMenu{display:none;}
section{ padding:80px 0;}
h2.section_title {
	font-weight: bold;
	text-align: center;
	padding-bottom: 25px;
	margin-bottom: 17px;
	position: relative;
	display: inline-block;
    left: 50%;
    transform: translateX(-50%);
}
/* h2.section_title::before {
    content: "";
    position: absolute;
    left: calc(-51px - 8px);
    top: 27%;
    transform: translateY(-50%);
    width: 57px;
    height: 57px;
    background-image: url(http://localhost:8888/hokuto/wp-content/uploads/rainbow.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}
*/
/*
h2.section_title::after {
    content: "";
    position: absolute;
    right: calc(-51px - 8px);
    top: 27%;
    transform: translateY(-50%) scaleX(-1);
    width: 57px;
    height: 57px;
    background-image: url(http://localhost:8888/hokuto/wp-content/uploads/rainbow.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
	background-color: transparent !important;
} */

.sitewrapper .header.fixed{ width:100%; z-index:999999999;}
.boxlayout{ width:1210px; margin:0 auto; box-shadow:0 5px 10px #000; position:relative; }
.boxlayout .container{ padding:0 20px;}
.boxlayout .footer{ padding:40px 20px;}
.boxlayout .header.fixed{ width:auto; left:0; right:0;}
.sitewrapper .header.fixed .header-top, .boxlayout .header.fixed .header-top{ display:none;}

/*Header Info Bar CSS*/
.headerinfo { font:600 14px/22px 'Roboto Condensed'; padding:10px 0; }
#slider {
	width: 100%;
	margin: 0;
	padding: 0;
	position: relative;
}
.logo{float:left;  text-align:left; padding:18px 0 10px 0;}
.logo h1{font-weight:600; margin:0px; text-transform:uppercase; }
.logo h1 span{ color:#ef2e2e; display:inline-block;}
.logo a{color:#000;}
.tagline{ font-size:14px; color:#828181; display:block;}
.header_right{ 
	float: right;
    text-align: right;
	margin-top: 6px;
}

.right span.phno{ padding-right:10px; margin-right:5px;}
.header-top{color:#fff; line-height:45px;}

.header-top .left span{padding-right:20px;}
.header-top .left a{color:#fff;}
.header-top .social-icons a{margin-right:0;}
.header-top i{ margin-right:10px;}
.header-top .right{ text-align:right;}
.right span.phno{ padding-right:10px; margin-right:5px;}

.infobox{ display:inline-block; float:right; margin:0 0 0 5%; text-align:right; text-transform:uppercase;}
.infobox span{ float:right;}
.infobox span b{ display:block; text-align:left; font-weight:300; }
.infobox i{ float:left; margin:9px 15px 0 0; width:30px; height:30px; line-height:28px; text-align:center; border:1px solid #6e6d6d; border-radius:50%; font-size:13px;}
.headwidjet{ display:none;}

a.booknow{padding:10px 30px; line-height:normal;position:absolute; right:0; top:45px; transform:translateY(-50%); color:#ffffff; background:#ff0000; font-weight:bold; -webkit-border-radius: 30px; -moz-border-radius: 30px; border-radius: 30px;}
a.booknow2 {
	width: 220px;
    height: 96px;
    font-size: 24px;
    line-height: normal;
    position: absolute;
    right: 0px;
    top: 0px;
    color: rgb(255, 255, 255);
    font-weight: bold;
    padding: 10px 33px;
	background: url(http://localhost:8888/chiba/wp-content/uploads/tell.png) no-repeat;
	background-size:contain;
}


/* = social icons css
-------------------------------------------------------------- */
.social-icons a{ width:38px; height:38px; line-height:38px; text-align:center;  vertical-align:middle; display:inline-block; padding:0; transition:0.6s; -moz-transition:0.6s; -webkit-transition:0.6s; -o-transition:0.6s; font-size:16px; color:#a3a9ab; }
.social-icons br{ display:none;}
.container-full { width:auto; margin:0 auto; position:relative;}
.container{ max-width:1170px; margin:0 auto; position:relative;}
.container-logoarea {
	width: 97%;
    margin: 0 auto;
	/* float: left; */
	position: relative;
}
.container-logoarea h1 {
	font-size: 1.6rem;
}

/*header menu css*/
.toggle{display: block;}
.toggle a{width:auto; color:#ffffff; background:url(images/mobilenav.png) no-repeat right center #3e3e3e; padding:10px 25px; margin-top:5px; font-size:16px; text-align:left;}
.toggle a:hover{color:#ffffff !important;}
.header.fixed{ position: fixed; top:0; z-index:999999;  transition:0.6s; -moz-transition:0.6s; -webkit-transition:0.6s; -o-transition:0.6s; width:auto; margin-top:0}
.header.fixed .sitenav ul li ul li a{ padding-top:7px; padding-bottom:7px; }

.header{width:100%; z-index:9999;box-sizing:border-box;}
.mainmenu{ background-color:#f6c311;}

sitenav{ padding:0; position:relative; z-index:9999; }
.sitenav ul {margin-top:8px; padding:0;}
.sitenav ul li{display:inline-block; position:relative;}
.sitenav ul li:last-child{border-right:none;}
.sitenav ul li a {font-weight: 600; padding:19px 12px; display:block; text-align:center; }
.sitenav ul li a:hover {opacity: .86;}
.sitenav ul li ul li{ display:block; position:relative; float:none; top:1px; border-bottom:1px #ddd solid;}
.sitenav ul li ul li a{ display:block; padding-top:7px; padding-bottom:7px; position:relative; top:0px; text-align:left;}
.sitenav ul li ul{display:none; z-index:9999999; position:relative; margin-top:-16px;} 
.sitenav ul li:hover > ul{display:block; width:240px; position:absolute; left:0; text-align:left;}
.sitenav ul li:hover ul li ul{display:none; position:relative;}
.sitenav ul li:hover ul li:hover > ul{display:block; position:absolute; left:240px; top:-1px;}
li#menu-item-54 a {
    color: #fff;
    background: #00a1a2;
    padding: 8px 21px;
    border-radius: 34px;
}

/* = innerbanner css 
-------------------------------------------------------------- */
.innerbanner{ text-align:center; position: relative;}
.innerbanner img{ position: relative; background-size:cover; width:100%; height:250px;}

/*search form css*/
.searchbox{position:relative; min-width:35px; width:0%; height:40px; float:right; overflow:hidden;padding-left:20px; -webkit-transition: width 0.3s;    -moz-transition: width 0.3s; -ms-transition: width 0.3s; -o-transition: width 0.3s; transition: width 0.3s;}
.searchbox-input{top:0; right:0; border:0;outline:0;background:#ece8e8;width:100%;height:40px;margin:0;padding:0px 55px 0px 20px;font-size:13px;color:#7f7f7f;}
.searchbox-input::-webkit-input-placeholder{color:#7f7f7f;}
.searchbox-input:-moz-placeholder{color:#7f7f7f;}
.searchbox-input::-moz-placeholder{color:#7f7f7f;}
.searchbox-input:-ms-input-placeholder{color:#7f7f7f;}
.searchbox-icon, .searchbox-submit{width:35px;height:40px;display:block;position:absolute;top:0;font-family:verdana;font-size:22px;right:0;padding:0 !important;margin:0 !important;border:0 !important;outline:0;line-height:40px;text-align:center;cursor:pointer;color:#dcddd8;background:url(images/search-icon.png) no-repeat center center #34c6f6;}
.searchbox-open{ width:40%;}

/* = Get An Appointment css
-------------------------------------------------------------- */
a.ReadMore{ font:normal 12px/20px 'Roboto Condensed'; border:1px solid #a4a4a4; color:#a4a4a4 ; padding:10px 20px; text-transform:uppercase; }
a.ReadMore:hover{border:1px solid #ef2e2e; color:#ef2e2e; }
.custombtn{ margin-top:30px;}

a.morebutton{padding:13px 40px; font-weight:500; display:inline-block; border-radius:5px;}
a.morebutton:hover{ background-color:#865628; color:#fff; }

a.buttonstyle1{ background-color:#865628; color:#fff ; padding:10px 20px; font:normal 16px/20px 'Roboto Condensed'; display:inline-block; border-radius:6px; -moz-border-radius:6px;-webkit-border-radius:6px;}
a.buttonstyle1:hover{ background-color:#381305; color:#fff; }

/* = Our Services css
-------------------------------------------------------------- */
#newswraper{ padding-bottom:10px;}
#welcomearea{ position:relative; background-color:#fff; padding:40px 0 50px; }

#whoweareasection{ background-color:#f2f1f1;}
.aboutwrap{ position:relative;}
.themefeatures{ color:#727272;}
.themefeatures h3{ font-size:28px; margin-bottom:25px;}
.best-featurs{ margin-bottom:20px; padding-bottom:20px;}
.best-featurs h4{ font-size:18px; font-weight:400; margin-bottom:10px; color:#999;}
.best-featurs i{ font-size:50px; float:left; margin:10px 35px 25px 0; color:#727272;}
.best-featurs:hover i{ color:#f6c311; }

/* = counter section css
-------------------------------------------------------------- */
.counterlist{float:left;font:bold 46px/1px 'Roboto Condensed';width:25%;padding:0 15px;box-sizing:border-box;text-align:center;margin:0;position:relative;}
.counterlist i{ font-size:32px; margin-bottom:30px;}
.counterlist .counter{ display:block; font-size:46px; color:#fff; line-height:28px; margin:0 0 35px 0;}
.counterlist h6{font-size:15px; opacity:0.8; margin:30px 0 0 0; padding:30px 0 0 0; text-transform:uppercase; position:relative;}
.counterlist h6:before{position:absolute; top:0; left:0; right:0; width:40px;margin:0 auto; border-bottom:solid 1px #ff0000; content:'';}
.countercon{text-align:center; width:100%;}
.processbox{ width:25%; float:left; background-color:#fff; color:#333; box-sizing:border-box; margin:0 0 20px 0; padding:15px; text-align:center; border-right:2px solid #eee; }
.processbox i{ font-size:35px; margin-bottom:20px; }
.processbox:hover h4{color:#fff;}

/* = Team Member Flipbox css
-------------------------------------------------------------- */
.team_column{ width:23%; float:left; margin:0 2% 2% 0; position: relative;	display:inline;	display: inline-block;}
.team_column h5{ margin-bottom:5px;}
.team_column h5 a{ color:#fff;}
.member-designation{ color:#2e2e2e; display:block; margin-bottom:15px; }

.og-grid li:hover .memmberdetails{ background-color:rgba(49,202,253,0.7); padding:10px 0; margin-top:-60px; position:relative; display:block;}
.memmberdetails h5{ font-size:18px; color:#fff; margin:0;}
.test{ position:relative;}
.team-thumb{ background-color:#696969; width:270px; height:310px; overflow:hidden;}
.team-thumb img{ width:100%; height: auto;}
.og-grid li:hover .team-thumb img{ opacity:0.6;}
.member-social-icon{ margin-bottom:20px;}
.member-social-icon a{ margin:0 2px 2px 0; display:inline-block; color:#000; width:35px; height:35px; line-height:35px;}
.member-social-icon a:hover{ color:#fff;}

.end { margin-right: 0 !important; }

.buttonstyle2{ background-color:#555; color:#fff ; padding:6px 15px; font:normal 14px/20px 'Roboto Condensed'; display:inline-block; border-radius:20px;-moz-border-radius:20px; -webkit-border-radius:20px;}
.buttonstyle2:hover{ background-color:#fff; color:#555; }
.textwidget select{ width:100%;}
table{ width:100%}

/* = section first css
-------------------------------------------------------------- */
#pagearea{margin:0;z-index:9999;position:relative;}
.threebox{width:25%;float:left;margin:0;padding:40px 30px; position:relative; min-height:300px; box-sizing:border-box; text-align:center;}
.threebox p{margin:0;}
.threebox h3{  font-weight:400; color:#404040; margin:10px 0 25px; text-transform:uppercase;}
a.ReadMore{ background-color:#333339; color:#fff ; padding:5px 15px; display:inline-block;}
a.ReadMore:hover{ background-color:#ffae00; color:#fff; }
.pagemore{padding:7px 15px; margin:25px 0 0 0; display:inline-block; text-transform:uppercase; border-radius:5px;}
.threebox:hover .pagemore{background-color:#ef2e2e;color:#ffffff;}
.threebox .thumbbx{width:100%; height:84px; margin:0 auto;overflow:hidden;} 
.threebox .thumbbx.imgbx{ height:160px;}
.threebox .thumbbx.imgbx img{ min-height:160px;}
.threebox .thumbbx img { height:auto; min-height:84px;width:auto;padding:0;}
.threebox.last_column .thumbbx{ border:none !important}
.pagecontent{padding:20px 0 0 0; position:relative; }
.one_column{width:100%;}
.two_column{width:50%;}
.three_column{width:33.333%;}
.four_column{width:25%;}
.five_column{width:20%;}
.six_column{width:33.333%;}

/* = Team Member Part css
-------------------------------------------------------------- */
#aboutsection{ padding-bottom:0;}

#attornerskill{ padding-bottom:0; }
#attornerskill .one_half{ width:35%;}
#attornerskill .one_half.last_column{ width:60%;}
#attornerskill .one_half img{ display:block; margin-top:-40px;}

.teamleft{ width:25%; float:left; box-sizing:border-box; padding-right:30px;}
.teamleft p{ margin-bottom:20px;}
.teamright{ width:70%; float:left;}


.teammember-list{width:25%;  display:inline-block; padding:0 15px; position:relative; box-sizing:border-box;}
.teammember-list:hover{ cursor:pointer;}
.teammember-list .thumnailbx{height:260px; width:260px; overflow:hidden; margin:0 auto 35px auto;-webkit-border-radius:100%; -moz-border-radius:100%; border-radius:100%; border-bottom:solid 10px #efeeee;}
.teammember-list .thumnailbx img{ vertical-align:middle; min-height:260px; width:100%; height:auto;} 
.teammember-list span.title{ font-weight:600; color:#555; font-size:16px; text-transform:uppercase; text-align:center; padding:0; margin:5px 0 0 0; display:block; position:relative;}

.teammember-list cite{ display:block; font-style:normal; margin-top:20px; color:#777; }
.titledesbox{ text-align:center; padding:8px 10px; position: relative; color:#ffffff; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
	

.member-social-icon{ display:none; left:0; right:0; position:absolute; top:50%; transform:translateY(-50%); text-align:center;}
.member-social-icon a{margin:0 0 5px 10px; text-align:center;display:inline-block;background-color:#fff;color:#727171; font-size:12px; width:35px; height:35px; line-height:35px; text-align:center; -webkit-border-radius: 3px;-moz-border-radius: 3px;border-radius: 3px;}
.member-social-icon a:hover{ color:#01c18d;}

.teammember-list:hover .thumnailbx img{ opacity:0.5;}
.teammember-list:hover .member-social-icon{ display:block;}

/*our project Carousel*/
#projectsection .item{ height:210px; overflow:hidden; background-color:#111; position:relative;}
#projectsection .item img{ height:auto; min-height:210px;}
#projectsection .item span{ position:absolute; left:31%; text-align:center; bottom:30%; z-index:99; background-color:#fff; border-radius:15px; font-weight:600; padding:5px 20px; display:none;}
#projectsection .item:hover img{opacity:0.2;}
#projectsection .item:hover span{ display:block; position:absolute; left:31%; text-align:center; bottom:30%; z-index:99; background-color:#fff; border-radius:15px; font-weight:600; padding:5px 20px; display:inline-block;}


/*  Our Blog  */
.blankspace{ height:60px; clear:both;}
/* = Latesr news section css
-------------------------------------------------------------- */
/* .news-box {
	width: 31.333%;
	min-height: 370px;
	float: left;
	margin: 0 25px 30px 0;
	position: relative;
	box-shadow: 0px 1px 34px #c6c6c6;
	overflow: hidden;
	border: 5px solid #f8e1ea;
}
.news-box.last { margin:0 ; padding:0 ;} */
/* .news-thumb{width:100%; height:320px; overflow:hidden; box-sizing:border-box; position:relative;} */
.news-thumb {overflow: hidden;}
.news-thumb img {
	width: 100%;
    height: auto;
	min-height: 120px;
    aspect-ratio: 16 / 9;
	margin-bottom: -7px;
	object-fit: cover;
	-webkit-transition: all .3s;
	transition: all .2s;
}
.news-box:hover .news-thumb img {
    transform: scale(1.1);
}
.news-thumb:hover img {
    transform: scale(1.1); /* ホバー時に1.1倍に拡大 */
}
.news-box:hover .news-thumb img{opacity:0.5}
.news-box h5{margin:5px 0 20px 0; line-height:1.2; text-transform:uppercase; font-weight:600 }
.news-thumb .PostMeta{font-size:16px; font-weight:500; background:#ffffff; padding:3px 10px;box-sizing:border-box; position:absolute; top:10px; left:10px;}
.news-box .postread{ font-weight:bold; }

h2.heading{ padding-bottom:15px;}
.underline{ border-bottom:1px solid #efeded;}
/*testimonials*/
.client-say{ width:80%; margin:0 auto;  position:relative; z-index:1; font:normal 16px/24px 'Roboto Condensed'; color:#333; }
.client-say .timthumb{ width:10%; float:left;}
.client-say .timthumb img{ height:100%; }
.client-say .tm_description{ width:87%; float:right;}

.client-say p{ margin-bottom:30px;}
.client-say h6{ color:#fff; margin:20px 0 0 0; text-transform:none; }

.promo-box{width:100%;height:auto; text-align:left;position:relative; font-size:17px;}
.promo-box h3{ margin:0 0 15px 0; padding:0; font-size:32px;}
.promo-left{float:left;width:75%}
 
.promo-right .morebutton{right:0; font-weight:bold;border-radius:25px;padding:10px 20px; position:absolute; top:50%; transform:translateY(-50%); -moz-transform:translateY(-50%); -ms-transform:translateY(-50%); -o-transform:translateY(-50%); -webkit-transform:translateY(-50%);}
 #promosection{ padding:40px 0 50px 0;}
 
.frdbox{ width:30.5%; float:left; margin:0 4% 4% 0; min-height:110px; box-sizing:border-box;}
.frdbox i{ color:#f6c311; float:left; margin:0 20px 0 0; text-align:center; font-size:60px; width:75px; }
.frdbox h4{ margin:0 0 10px; padding-bottom:15px; color:#444; position:relative;}

.frdbox h4::after{
 content:"";
 position:absolute;
 width:50px;
 bottom:0;
 left:28%;
 margin:auto;
 border-bottom:1px solid #f6c311;
}

.frdbox p{ margin-left:95px;}
.frdbox.last{ margin-right:0;}
.last{ margin-right:0 !important;}

/* = Testimonials css
-------------------------------------------------------------- */
#section6 h2.section_title span{ position:relative; padding:0 0 15px 0}
#section6 h2.section_title span:after{border-bottom:solid 2px #ff0000; content:''; position:absolute; bottom:0; left:0; width:60px;}
#clienttestiminials{box-sizing:border-box; position:relative; }
#clienttestiminials h6{ margin:0px; text-transform:capitalize; position:relative; padding:40px 0 0 0;}
.thumb-title{ float:left; margin:0 50px 0 0;}
#clienttestiminials .tmthumb{ width:200px; height:200px; margin:0; position:relative}
#clienttestiminials .tmthumb:after{ border:solid 5px #ff0000; height:195px; width:195px; position:absolute; content:''; right:10px; top:10px;}
#clienttestiminials .tmthumb img{ width:100%; height:auto; min-height:200px; position:relative; z-index:999999;}
#clienttestiminials .leftttl{ text-align:center}
#clienttestiminials .item{ width:82%; margin:0 auto; font-size:14px; position:relative;}
.arrow_box {padding:40px 0; box-sizing:border-box; position:relative; margin:0;}
.arrow_box i{ float:left; margin-right:20px; font-size:20px;}
.arrow_box p{ display:table}
.testimonials-area{background:rgba(1, 193, 141, 0.8); box-sizing:border-box; margin:0 auto; padding:45px 80px 10px; width:65%;}

/*testimonials listing*/
.tmnllisting{ margin-bottom:35px; min-height:120px;}
.tmnllisting .tmnlthumb{ float:left; width:120px; height:120px; margin:0 5% 0 0; overflow:hidden;}
.tmnllisting .tmnlthumb img{ width:100%; height:100%; border-radius:50%;}
.tmnllisting h6{ margin-bottom:10px; padding-top:10px; text-transform:uppercase;}

#testimonials-widget h6{ margin-bottom:5px; text-transform:uppercase;}
#testimonials-widget p{ margin-bottom:15px;}
/* --------- Pages ------- */
.content-area{ padding:30px 20px;}
.content-area2 { padding:30px 0;}
.site-main{ width:800px; margin:0; padding:0; float:left;}
.sitefull{ width:100% !important;}
#sidebar{ width:300px; float:right;}
.sidebar-left{ float:left !important;}
/*.sidebar-left #sidebar{ width:auto;}*/
.flotRight{ float:right !important;}
/*sidebar css*/
aside.widget{margin-bottom:30px; border-bottom:double #ccc; padding-bottom:20px;}
aside.widget ul{ list-style:disc; }
h3.widget-title{ padding:0; margin-bottom:15px; color:#515151; font-size:24px; }
#sidebar #contactform_main input[type=text], #sidebar #contactform_main input[type=email], #sidebar #contactform_main input[type=tel],#sidebar #contactform_main input[type=url], #sidebar #contactform_main textarea{width:90%; }
#sidebar #contactform_main p{ margin-bottom:10px;}

#sidebar ul li{ list-style: disc inside ; border-bottom:1px dashed #d0cfcf; padding:8px 0 8px 0;}
#sidebar ul li a{ font:300 14px/18px "Roboto Condensed",sans-serif;  padding-left:10px; color:#3b3b3b; }
#sidebar ul li a:hover{ color:#34c6f6;}
#sidebar ul li:last-child{ border:none;}
.nosidebar{ float:none !important; margin:0 auto;}

#sidebar .search-form input.search-field{ background-color:#f0efef; width:80%; padding: 11px 15px; box-sizing:border-box;}
#sidebar .search-form input.search-submit{ background:url(images/search-icon.png) no-repeat center center #ef2e2e; padding: 12px 0 12px 0; font-size:0; width:20%; height:41px; float:right;}

/* = skill bar css
-------------------------------------------------------------- */
#skillwrap{ padding:0;}
.skillbar {position:relative; display:block; margin-bottom:25px; width:100%; height:40px; -webkit-transition:0.4s linear; -moz-transition:0.4s linear; -ms-transition:0.4s linear; -o-transition:0.4s linear; transition:0.4s linear; -webkit-transition-property:width, background-color; -moz-transition-property:width, background-color; -ms-transition-property:width, background-color; -o-transition-property:width, background-color; transition-property:width, background-color;}
.skillbar-title { font:16px 'Roboto Condensed',san-serif;color:#6e6d6d;}
.skillbar-title span { display:block; color:#000; padding:0; height:40px; line-height:45px; text-align:left;}
.skillbar-bar { height:2px; width:0px; background:#65676a; }
.skill-bar-percent { position:absolute; right:0; top:0; font-size:15px; height:3px; line-height:35px; color:#000;}
.skill { width:46.98%; float:left;}
.skill-bar { margin:60px 0 0 0;}
.skill-bg{ padding:3px 0; width:100%; background-color:#FFFFFF;}

/* = Footer css
-------------------------------------------------------------- */
#footer-wrapper {
	background: linear-gradient(169deg, #d9feff, #40bcbd);
	position: relative;
	color: #c1c0c0;
	background-size: cover !important;
}
.footer{ padding:70px 0 50px 0;}
.footer h5{font-weight:600; margin-bottom:20px; padding:0 0 20px; position:relative;}
.footer a.readmore span{ color:#fff;}
.footer ul li{list-style:none;margin:0 0 5px 0;display:block;position:relative;}
/* .footer ul li a:before{content:"\f105"; font-family:'Font Awesome 5 solid'; font-size:14px;padding-right:10px}
.footer ul li a{ padding:0; display:inline-block; color:#6a6a6a;}
.footer ul li a:hover, .footer ul li.current_page_item a{ color:#ef2e2e;} */
menu-item-54 {
	color: #fff;
    background: #00a1a2;
    border-radius: 43px;
    padding: 8px 24px;
}

/*footer recent post*/
ul.recent-post{ margin:0px; padding:0px; list-style:none;}
ul.recent-post li{ display:block; line-height:18px; margin-bottom:20px; min-height:55px; list-style:none; border-bottom:1px dashed #333333;}
ul.recent-post li strong{ padding-bottom:10px; font-size:16px; display:block;}
ul.recent-post .footerthumb{ width:90px; height:80px; overflow:hidden; float:left; margin:0 15px 0 0;}
ul.recent-post li img{width:100%; height:auto; margin-top:4px;}
ul.recent-post li span{font-size:11px;}
ul.recent-post li a{text-decoration:none; padding:0; border:none; display:block;}
ul.recent-post li a:before{display:none !important; visibility:hidden; opacity:0;}
ul.recent-post li a:hover {text-decoration:none;}
ul.recent-post li:last-child {border-bottom:0; padding-bottom:0; margin-bottom:0;}


.footerlogo{ margin-bottom:25px;}
.contactdetail{ line-height:22px; } 
.contactdetail i{ margin-right:20px; font-size:16px;}
.contactdetail p{ margin-bottom:10px;}

/*Footer Manageable css*/
.cols-1 .widget-column-1{ width:100%; float:none; text-align:center;}
.cols-1 .widget-column-1 ul li{ display:inline-block; border:none;}
/* .cols-1 .widget-column-1 ul li a{ padding:0 15px; height:12px; line-height:10px; display:block; border-right:1px solid} */
.cols-1 .widget-column-1 ul li:last-child a{border:none;}

.cols-2 .widget-column-1{width:45%; float:left; margin:0 10% 0% 0; box-sizing:border-box; }
.cols-2 .widget-column-2{width:45%; float:left; margin-right:0px; box-sizing:border-box;}

.cols-3 .widget-column-1{width:23%; float:left; margin:0 6% 0 0; box-sizing:border-box; }
.cols-3 .widget-column-2{width:36%; float:left; margin:0 6% 0 0; box-sizing:border-box;}
.cols-3 .widget-column-3{width:29%; float:left; margin-right:0px; box-sizing:border-box;}

/* footer 4 column css*/
.cols-4 .widget-column-1{ width:24%;  float:left; margin:0 4% 0 0; box-sizing:border-box; }
.cols-4 .widget-column-2{ width:16%;  float:left; margin:0 4% 0 0; box-sizing:border-box;}
.cols-4 .widget-column-3{ width:24%;  float:left; margin:0 4% 0 0; box-sizing:border-box;}
.cols-4 .widget-column-4{ width:24%;  float:left; margin-right:0; box-sizing:border-box;}

.copyright-wrapper {
	font-size: 1rem;
    color: #fff;
    position: relative;
    padding: 15px 0;
}
.copyright-txt{float:none; text-align: center;}
.design-by{float:right;}

.footer .social-icons{ margin-top:20px;}
.footer .social-icons a{ width:35px; height:35px; line-height:35px; margin:0 5px 5px 0; padding:0; color:#c1c0c0; }
.footer .social-icons a:hover{ color:#ef2e2e; }
.footer .social-icons a, #footer-info .social-icons a{ margin-right:5px;}
#footer-info{ width:100%; padding:30px 0; background:#141414; }
#footer-info .cols-2 h5{ font-size:21px !important; float:left; padding-right:20px; padding-top:10px;}
#footer-info .cols-2 .widget-column-1{ padding-right:2.5%; width:50%; box-sizing:border-box; margin:0;}
/* = Contact Form css
-------------------------------------------------------------- */
.wpcf7{ margin:0; padding:0; }
.wpcf7 form{ margin:0; padding:0;}
.wpcf7 form span.last{ float:none !important;}
.wpcf7 form input[type="url"], .wpcf7 form input[type="date"], .wpcf7 form select{ background-color:#f1f1f1; border:1px solid #000; padding:5px 3px; font:13px arial; color:#777777;}
/* .wpcf7 form input[type="checkbox"], .wpcf7 form input[type="radio"], .wpcf7 form input[type="file"]{ margin-top:10px; padding:0;} */
span.wpcf7-list-item{ margin:0 15px 0 0 !important;}
#contactform_main input[type=text], #contactform_main input[type=email], #contactform_main input[type=tel], #contactform_main input[type=url], #contactform_main textarea{width:100%; border:1px solid #000; padding:15px; margin:0 0 8px 0;}   
#contactform_main textarea{ width:100%; margin-right:0; height:130px;} 
#contactform_main span.capcode{ float:left; padding:13px; padding:13px; margin:0 8px 8px 0;}   
#contactform_main input[type=submit], .wpcf7 form input[type="submit"] { font:400 20px/24px; text-transform:uppercase; cursor:pointer; border-radius:5px; width:100% !important; height:60px; font-size:20px;}
.wpcf7 form input[type="submit"]:hover { font:400 20px/24px; text-transform:uppercase; cursor:pointer; width:100% !important; font-size:20px;}
/*iphone用*/
input[type="submit"]{
-webkit-appearance: none;
}

.wpcf7 form input[type="text"], .wpcf7 form input[type="email"], .wpcf7 form input[type="tel"], .wpcf7 form textarea{ border:1px solid #000; padding:15px; margin:0 8px 8px 0;  }
.wpcf7 form textarea{ margin-right:0; height:130px;} 

/*Reservation form css*/
.wpcf7 form input[type="text"], .wpcf7 form input[type="email"], .wpcf7 form input[type="tel"], .wpcf7 form textarea{ width:100%; background-color:#fff; color:#000; padding:10px 15px; }
.wpcf7 form{ margin-bottom:6px;}
.wpcf7 form input[type="submit"] { font:400 20px/24px; text-transform:uppercase; cursor:pointer; width:30%; }

#portfoliosection .container{ width:100%; box-sizing:border-box; -moz-box-sizing:border-box; -webkit-box-sizing:border-box;}


/** home page contact form **/
.homecontact{width:100%;margin:0 -5px;padding:0;box-sizing:border-box;}
.homecontact p{margin:0; padding:0;}
.contleft, .contright{width:25%;box-sizing:border-box;}
.contleft{float:left; padding:5px;}
.contright{float:right; padding:5px;}
.homecontact input[type="text"], .homecontact input[type="email"], .homecontact input[type="tel"], .homecontact textarea{margin:0 !important; width:100%; box-sizing:border-box; padding:30px 15px !important; border:none;}
.wpcf7-select{border:none; width:100%; /* margin:0 0 30px 0 !important; */}
.homecontact input[type=submit]{ float:none; margin:0 auto; display:block; }
.homecontact .wpcf7-textarea{height:180px; padding-left:40px;}
.homecontact .left{width:50%; padding:0; box-sizing:border-box;}
.homecontact .right{width:50%; padding:0; box-sizing:border-box;}

.homecontact .wpcf7-select{border:none !important;  padding:30px 15px !important; appearance:none; -ms-appearance:none; -moz-appearance:none;-webkit-appearance:none; margin:0 0 5px 0 !important}
.homecontact input[type="submit"] { margin:15px auto 0 auto !important; font-size:19px; font-weight:500}

.namefield{background:#ffffff url("images/icon-man.png") no-repeat scroll right center !important;}
.cargofield{background:#ffffff url("images/icon-cargofield.png") no-repeat scroll right center !important;}
.locationfield{background:#ffffff url("images/icon-locationfield.png") no-repeat scroll right center !important;}
.transportfield{background:#ffffff url("images/icon-transportfield.png") no-repeat scroll right center !important;}

.emailfield{background:#ffffff url("images/icon-email.png") no-repeat scroll right center !important;}
.webfield {background:#ffffff url("images/icon-webfield.png") no-repeat scroll right center !important;}
.phonefield{background:#ffffff url("images/icon-phone.png") no-repeat scroll right center !important;}
.messagefield{background:#ffffff url("images/icon-message.png") no-repeat scroll right center !important;}


iframe{ width:100%;}
.contactpage_left{ float:left; width:65%; background-color:#f2f2f2; padding:25px; box-sizing:border-box; }
.contactpage_right{ float:right; width:30%;}
.contactpage_right h3{ margin-bottom:15px;}

.post-title{ margin-bottom:0px; font-weight:400;}
.post-title a{ color:#3d3d3d;}

.blog-post-repeat {
    max-width: 800px;
    border-radius: 20px;
    margin: auto;
    background: #f0faff;
    padding: 30px 24px;
    box-shadow: 0px 1px 16px 4px #dcdcdc;
}
.blog-post-repeat ul li {
    padding: 8px 0;
}
.blog-post-repeat .postmeta{ border-bottom:1px solid #e8e8e8; margin-bottom:15px;}
p.read-more a{ background-color:#ff6565; color:#fff; text-align:center; padding:5px 15px;  display:inline-block; border-radius:2px; -moz-border-radius:2px; -webkit-border-radius:2px;}
p.read-more a:hover { background-color:#34c6f6;}
.blog-post-repeat .post-thumb img{ float:left; margin-right:15px; margin-bottom: 20px; height:auto;}

/*default css*/
.error_msg{padding:10px; background:#ffd3ce; color:#e00; border:1px #e00 solid; margin:15px 0;}
.success_msg{padding:10px; background:#dcffc5; color:#070; border:1px #070 solid; margin:15px 0;}
.spacer20{height:20px; clear:both;}
.pagination{display:table; clear:both;}
.pagination ul{list-style:none; margin:20px 0;}
.pagination ul li{display:inline; float:left; margin-right:5px;}
.pagination ul li span, .pagination ul li a{background:#303441; color:#fff; padding:5px 10px; display:inline-block;}
.pagination ul li .current, .pagination ul li a:hover{background:#34c6f6;}
article.tag-sticky-2{background:#f6f6f6; padding:10px;}

h1.entry-title{font-weight:600; font-size:30px; text-transform:uppercase; margin-bottom:30px; position:relative;}
article p{margin:0 0 20px 0;}
.post-date{display:inline;}
.post-comment{display:inline;}
.post-categories{display:inline;}
.post-tags{display:inline;}
form.search-form{margin-bottom:20px;}
input.search-field, .post-password-form input[type=password]{border:1px #eee solid; padding:7px 15px;}
input.search-submit, .post-password-form input[type=submit]{border:none; color:#ffffff; padding:7px 15px; cursor:pointer; }
#contactform_main p{ margin-bottom:0;}
.nav-previous{float:left; margin-top:10px; margin-bottom:10px;}
.nav-next{float:right; margin-top:10px; margin-bottom:10px;}
nav.post-navigation{padding:10px 0 20px;}
.comment-list, ol.comment-list{list-style:none; margin-left:0; margin-top:20px; margin-bottom:20px;}
.comment-list ul, ol.comment-list ul{list-style:none;}
.comment-list li.comment{margin-top:20px;}
.comment-list .comment-content h1, .comment-list .comment-content h2, .comment-list .comment-content h3, .comment-list .comment-content h4, .comment-list .comment-content h5, .comment-list .comment-content h6{margin-top:15px;}


/* Buttons */
.button{ background-color:#f6c311; color:#fff; font:400 15px/22px 'Roboto Condensed', sans-serif; padding:12px 25px; display:inline-block;}
.button:hover{background-color:#202020; border-color:#1898c2; color:#fff;}

/* Text meant only for screen readers. */
.screen-reader-text {clip: rect(1px, 1px, 1px, 1px);position: absolute !important;	height: 1px;width: 1px;	overflow: hidden;}
.screen-reader-text:focus {	background-color: #f1f1f1;	border-radius: 3px;	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);	clip: auto !important;	color: #21759b;	display: block;
	font-size: 14px;font-size: 0.875rem;font-weight: bold;	height: auto;left: 5px;	line-height: normal;padding: 15px 23px 14px;text-decoration: none;	top: 5px;	width: auto;
	z-index: 100000; /* Above WP toolbar. */
}
/* Best Offer CSS
================================================*/
.offerwrap .one_half{ width:31%; cursor:pointer; margin:0;}
.offer-1-column{ position:relative;}
.offer-1-column .offimgbx{ background-color:#ef2e2e; height:358px; overflow:hidden;}
.offer-1-column .offimgbx img{ min-height:358px; height:auto; width:100%;}
.offdesc{ position:absolute; top:0; color:#fff; padding:50px; text-align:center; display:none;}
.offer-1-column:hover .offdesc{ display:block; }
.offer-1-column:hover .offimgbx img{ opacity:0.1;}
.offdesc h6{ margin-bottom:20px; text-transform:uppercase; color:#fff; font-size:22px; font-weight:600;}
.offdesc h6 span{ color:#111;}
.offdesc h5{ margin-bottom:30px; text-transform:uppercase; color:#fff; font-size:24px; font-weight:600; padding-bottom:20px; position:relative; line-height:32px;}
.offdesc h5::after{ content:""; position:absolute; width:100px; height:2px; background-color:#fff; bottom:0; left:0; right:0; margin:auto;}

.offdesc p{ font-size:15px;}
.offerwrap .one_half.last_column{ width:69%}

.offer-2-column{ width:45%; float: left; margin:0 0 29px 5%;}
.offerimgbox{ width:33%; margin:0 7% 0 0; float:left; height:100px; overflow:hidden;}
.offerimgbox img{ width:100%; height:auto; min-height:100px;}
.offcontnt{ width:60%; float:left; line-height:16px;}
.offcontnt .pricedv{font:600 16px/18px "Roboto Condensed",sans-serif; color:#ef2e2e; margin:10px 0; }
.offcontnt .pricedv span{ margin-right:10px; color:#999; text-decoration:line-through; font-weight:400;}
.offcontnt h4{ font-size:16px; text-transform:uppercase; margin-bottom:15px;}

/*Missionvission css*/

#ourrecruiters{ text-align:center; font-size:15px;}
.our-recruiters{ margin:0; padding:0;}
.our-recruiters li{ float:left; margin:0 10px; width:18%; box-sizing:border-box;}
.clientleft{ width:30%; float:left; margin-right:5%; text-align:left;}
.clientleft p{color:#fff;}
.clientright{ width:65%; float:right; margin:0;}
ul#clientlogos{ margin:0 -15px; float:left; position:relative;}
ul#clientlogos li{float:left;margin:0; padding:0 15px; width:20%; box-sizing:border-box; text-align:center; height:105px; overflow:hidde;}
ul#clientlogos li img{ height:auto; min-height:100px;}
#ourclients h2.section_title{ text-align:left; text-transform:none; padding-bottom:15px; color:#fff !important;}
#ourclients h2.section_title::after{ content:"";position:absolute;width:80px;border-bottom:2px solid #fff; bottom:0; left:0; right:auto; margin:auto;}
#section8 ul#clientlogos li{ width:20%; padding:0 0 0 20px;}
#section8 .one_fifth{ margin-bottom:0;}

/* woocommerce CSS
================================================*/
a.added_to_cart{background:#e1472f; padding:5px; display:inline-block; color:#fff; line-height:1;}
a.added_to_cart:hover{background:#000000;}
a.button.added:before{content:'' !important;}
#bbpress-forums ul li{padding:0;}
#subscription-toggle a.subscription-toggle{padding:5px 10px; display:inline-block; color:#e1472f; margin-top:4px;}
textarea.wp-editor-area{border:1px #ccc solid;}
.woocommerce input[type=text], .woocommerce textarea{border:1px #ccc solid; padding:4px;}
form.woocommerce-ordering select{ padding:5px; color:#777777;}
.woocommerce table.shop_table th, .woocommerce-page table.shop_table th{ font-family:'Roboto Condensed',san-serif; color:#ff8a00;}
.woocommerce ul.products li.product .price, .woocommerce-page ul.products li.product .price{ color:inherit !important; font-size:15px;}
h1.product_title, p.price{margin-bottom:10px;}
.woocommerce table.shop_table th, .woocommerce-page table.shop_table th{ font-family:'Roboto Condensed',san-serif; color:#ff6d84;}
.woocommerce table.shop_table th, .woocommerce table.shop_table td{ border-bottom:0px !important}
.woocommerce ul.products li.product .price del{ display:inline-block;}
.woocommerce ul.products li.product h3{ font-size:18px; position:relative; padding-bottom:15px; margin-bottom:10px;}
.woocommerce ul.products li.product h3::after{ content:""; position:absolute; width:50px; height:1px; background-color:#555; bottom:0; left:0; right:0; margin:auto;}

.woocommerce .quantity .qty{padding:7px;}
.woocommerce-Price-amount.amount{font-size:14px !important;}
.woocommerce div.product .product_title{padding-bottom:20px !important;}
.woocommerce div.product form.cart{ margin-top:15px !important;}
.home .woocommerce ul.products li.product .price, .home .woocommerce .star-rating{ display:none;}

.woocommerce ul.products li .product_type_simple{ position:absolute; opacity:0; top:100px; left:50%; transform:translateX(-50%); margin:0 auto !important; text-align:center; color:#161616 !important;  background:#ffffff !important; -webkit-border-radius: 30px;-moz-border-radius: 30px;border-radius: 30px; padding:15px 35px 12px 35px !important; display:table!important; transition:all .5s ease 0;}
.woocommerce ul.products li:hover .product_type_simple{opacity:1; transition:all .5s ease 0; }
.woocommerce ul.products li.product a img { min-height:270px;}
.woocommerce ul.products li .woocommerce-loop-product__title{ font:normal 17px 'Roboto'; text-align:center; padding:15px 15px !important; position: relative; background: #ff0000; color:#ffffff; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px;}
.woocommerce ul.products li .woocommerce-loop-product__title:after{	bottom: 100%; left: 50%; border: solid transparent;	content: " "; height: 0; width: 0; position: absolute; pointer-events: none; border-color: rgba(255, 255, 255, 0); border-bottom-color: #ff0000; border-width: 9px; margin-left:-9px;}
.woocommerceright{float:left;}
.woocommerceleft{float:right;}
.woocommercesitefull{ width:100%;}
.woocommerce .panel{ height:auto}

.subtitle{text-align:center;padding:0 120px; position:relative; display:table; margin:0 auto 20px auto;}

.leftborder{width:100px; border-bottom:1px solid transparent; content:''; position:absolute; left:0; top:50%; transform:translateY(-50%); -webkit-transform:translateY(-50%); -moz-transform:translateY(-50%);}
.rightborder{ width:100px; border-bottom:1px solid transparent; content:''; position:absolute; right:0; top:50%; transform:translateY(-50%); -webkit-transform:translateY(-50%); -moz-transform:translateY(-50%);}

.shortdesc{ text-align:center; padding:0;  position:relative; margin:0 auto 20px; width:70%;}


/*post nav css*/
.post-nav{ clear:left; margin-top:40px;}
.prev-page, .next-page{ margin:0; padding:0;}
.prev-page a{ float:left;}
.next-page a{ float:right;}
.prev-page a, .next-page a{background-color:#515151; padding:5px 10px; color:#ffffff; font:15px 'Roboto Condensed',san-serif;}
.prev-page a:hover, .next-page a:hover{ color:#ffffff; background-color:#34c6f6;}
.singleright { float:left; }
.singleleft { float:right; }
/*back to top css*/
#top{ position:relative;}
#back-top {	position: fixed; bottom: 120px; right:15px; transform: rotate(270deg) !important;}
#back-top a {width:64px;display:block;text-align:center;font:11px/100% Arial, Helvetica, sans-serif;text-transform:uppercase;text-decoration:none;color:#bbb;-webkit-transition: 1s;-moz-transition:1s;transition:1s;}
#back-top:before {
    content: "\f04b";
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    font-size: 42px;
    cursor: pointer;
    /* background: linear-gradient(258deg, #8fe6ff, #2d64b6); */
	background: #00a1a2;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: #2d64b6;
}

.space{clear:both;min-height:10px;}
.skills-wrap{ width:60%; margin:0 auto; text-align:center;}
/* #back-top span {width:42px;height:42px;	display: block;	margin-bottom: 7px;	background: url(images/up-arrow.png) no-repeat center center; -webkit-transition: 1s;	-moz-transition: 1s;transition: 1s;opacity:0.5;} */
.sitefull .fourcol .entry{width:24%;}
/* .slider-main{min-height:300px;overflow:hidden;position:relative; background:url(images/loading.gif) no-repeat center center #fff;} */

.slider-main {
	min-height: 180px !important;
	overflow: hidden;
	position: relative;
	height: auto;
	background: url(images/loading.gif) no-repeat center center #fff;
}
.slider-main img {
	z-index: 1;
}
.slider-main::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        135deg,
        rgba(15 116 111 / 74%) 0%,
        rgba(170, 242, 223, 0.3) 55%,
        rgba(255, 255, 255, 0.1) 66%
    );
    z-index: 10;
    pointer-events: none;
}
.fv-recruit {
	display: block;
	position: absolute;
	left:60px;
	bottom:80px;
	width:360px;
	height: 120px;
    border-radius: 20px;
	background: #fff;
	z-index:12;
	box-shadow: 3px 1px 11px 3px #e1e0e0;
	/* border: 3px solid #00a1a2; */
	background: url(https://houkan-hokuto.com/wp-content/uploads/hero01.jpg) no-repeat;
	background-size: cover;
	background-position: 0 44%;
	transition: all 0.3s ease;
}
a.fv-recruit:hover {
    transform: translateY(-4px);
    box-shadow: 0 4px 12px rgb(219 134 217 / 40%)
}
.fv-recruit h2 {
	color: #00a1a2;
    font-size: 1.8rem !important;
    font-weight: 800;
    padding: 20px;
	margin-bottom: 0;
}
.recruit-btn {
	color: #00a1a2;
	padding-left: 20px;
	font-size: 1rem;
	font-weight: 600;
}
.recruit-btn i {
    margin-right: 7px;
    border: 1px solid #00a1a2;
    padding: 6px 8px 6px 6px;
    border-radius: 50%;
}
.fa-solid {
    font-family: 'Font Awesome 5 Free';
}
.hero-copy {
	color: #022488;
	position:absolute;
	font-size: 2.6rem;
    font-weight: 600;
    top: 280px;
	left:80px;
	padding: 20px 30px 20px 20px;
	z-index: 9;
	background: linear-gradient(to right, #fff 98%, transparent 100%);
}
.hero-txt {
	color: #022488;
	position:absolute;
	font-size: 1.4rem;
	font-weight: 600;
	top: 335px;
    left: 80px;
    padding: 10px 20px 11px;
    z-index: 10;
	background: linear-gradient(to right, #fff 98%, transparent 100%);
}
#transportservices{ position:relative; background-color:#f6f6f6;}
#transportservices h2.section_title{ text-align:left; font-size:44px;}
#transportservices h2.section_title:after{width:60px;left:0;bottom:0;border-bottom:solid 2px #ff0000;content:'';position:absolute;}
.box-border{ border:solid 6px #ff0000; padding:60px 40px; box-sizing:border-box;}
#transportservices .one_half { position:relative;}
#transportservices .one_half .whar-we-do-image{position:absolute;left:-80px;top:40px; width:630px; height:425px; overflow:hidden;}
#transportservices .one_half.last_column{ padding:60px 0 0 100px !important; box-sizing:border-box;}

/* Services */
.servicebox{float:left;width:50%;  margin:0 0 50px 0; padding:0; box-sizing:border-box; position:relative; z-index:999999;}
.servicebox-icon{ margin:0 30px 0 0; float:left; width:61px; height:44px; overflow:hidden;}
.servicebox-icon img{ vertical-align:middle;}
.servicebox h6{font-weight:400; padding:0; display:inline-block; margin:15px 0 0 0; text-transform:uppercase;transition:0.6s; -moz-transition:0.6s; -webkit-transition:0.6s; -o-transition:0.6s; font-size:15px}

.newsletter-form{position:relative; margin-bottom:15px; padding-bottom:15px;}
.newsletter-form input[type="email"]{border:medium none;border-radius:5px;box-sizing:border-box;padding:13px;width:100%}
.newsletter-form i{background-color:#141414; -webkit-border-radius: 5px;-moz-border-radius: 5px;border-radius: 5px;color:#fff;font-size:16px;height:37px;line-height:37px;position:absolute;right:3px; top:2px; -webkit-transition:all .3s;transition:all .3s;text-align:center;width:40px}
.newsletter-form input[type="submit"]{background-color:transparent;border:medium none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;height:100%;position:absolute;right:0;-webkit-transition:all .3s;transition:all .3s; }

.wearesuprime {width:100%; margin:0; display:block;}
.wearesuprime .about-humb{width:46%; position:relative;  float:left;margin:0; z-index:999; height:465px; overflow:hidden;}
.wearesuprime .about-humb img{width:100%;}
.wearesuprime .abouttitledes{font-size:17px;font-weight:300;width:54%;overflow:hidden;float:right; box-sizing:border-box; padding:40px 50px 0 70px}
.wearesuprime .abouttitledes-full{width:100%; height:auto; float:none; padding:5%;}
.wearesuprime .abouttitle h4{color:#282828; position:relative; margin:0; padding:0 0 25px; font-weight:bold; font-size:44px; text-transform:uppercase; }
.wearesuprime .abouttitle h4 span{ font-weight:500}
.wearesuprime .aboutdesc{display:table;}
.wearesuprime .aboutmore{display:block; margin:60px 0 0 0;}
.wearesuprime .aboutmore a{ color:#FFFFFF !important; padding:10px 35px; -webkit-border-radius: 25px; -moz-border-radius: 25px;border-radius: 25px; display:inline-block; font-weight:bold}
.wearesuprime .aboutmore:hover a{ opacity:0.8} 

#section1 .one_half{width:70%; margin:0;}
#section1 h2.section_title, #section7 h2.section_title{ color:#ffffff;}

.features{ width:50%; box-sizing:border-box; padding:20px 30px 20px 0; float:left; }
.features-thumb{width:81px;height:81px;line-height:81px;margin:0 20px 20px 0;border:solid 1px #ff0000;-webkit-border-radius:100%;-moz-border-radius:100%;border-radius:100%; float:left; text-align:center}
.features-thumb img{ width:41px; min-height:37px;line-height:81px;vertical-align:middle;}
.features h5{ font-size:24px; font-weight:500; margin-bottom:10px; text-transform:uppercase;}
.features p{ color:#858484;}


p.p-center{text-align:center; width:65%; margin:0 auto 20px auto;box-sizing:border-box}
p.color-gray{color:#6f6f6f}

#section2 h2.section_title{text-align:left; margin:0 0 10px 0; padding:0;}
#section2 ul li i{ margin-right:10px;}
#section2 ul li{ margin-bottom:10px;}

#section4 {
	padding: 0 !important
}

#section5 h2.section_title{text-align:left; margin:0 0 10px 0; padding:0;}
.slider-below-image{margin:-90px auto 0 auto; position:relative; z-index:999999; text-align:center}

/* PRICING TABLE */
.plans{ text-align:center;}
.plans .plan-box{background-color:#ffffff; box-sizing: border-box; display:inline-block; margin:15px 55px 15px 0;position: relative;text-align: center;}
.plan-content{padding:0 30px;}
.plans .plan-box-inner{ padding:30px 0; overflow:hidden; position:relative;}
.plans .plan-title{font-size:21px; margin:0; font-weight:bold; padding:20px 10px;}
.plans .plan-price{color:#282828; border:solid 1px #ff0000;font-size:55px; font-weight:bold; margin:20px auto 15px auto; padding:25px 5px 5px 5px; width:140px; height:140px;-webkit-border-radius:100%;-moz-border-radius:100%;border-radius:100%; box-sizing:border-box; vertical-align:middle; position:relative}
.plans .plan-price-border{ position:relative;}
.plans .plan-price-border:before{width:105px; height:1px; border-bottom:solid 1px #ff0000; content:''; position:absolute; left:0; top:50%; transform:translateY(-50%); -webkit-transform:translateY(-50%); -moz-transform:translateY(-50%);}
.plans .plan-price-border:after{width:105px; height:1px; border-bottom:solid 1px #ff0000; content:''; position:absolute; right:0; top:50%; transform:translateY(-50%); -webkit-transform:translateY(-50%); -moz-transform:translateY(-50%);}
.plans .plan-price .firstletter{font-size:23px;position:relative;top:5px;left:0;display:inline-block;vertical-align:top; padding:0 2px 0 0}
.plans .plan-price span{ font-size:16px; display:block; font-weight:400; padding:10px 0 0 0;}
.plans .plan-price sup{font-size: 18px; margin-right: 3px; position: relative; top:-4px;}
.plans .plan-content li{list-style: none; padding:6px 0; font-size:19px; color:#292929;}
.plans .plan-button{padding:40px 0 20px 0;}
.plans .plan-button a{ border:solid 2px #ff0000; color:#292929; display:inline-block;font-weight:bold;padding:10px 45px;font-size:19px;-webkit-border-radius:30px;-moz-border-radius:30px;border-radius:30px;}
.plans.has-popular .plan-box.popular-plan .plan-button a{background:#ff0000; color:#ffffff;}
.plans.has-popular .plan-box.popular-plan .plan-price{ background:#ff0000; color:#ffffff;}
.star-strip{ background:#ff0000; height:35px; width:150px; position:absolute; left:-40px; top:30px;transform: rotate(-50deg);}
.star-strip i{ color:#ffffff; padding:0 0 0 4px; font-size:14px; vertical-align:middle;}
.plans-3column .plan-box{width:30%;}
.plans-3column .plan-box:nth-of-type(3){margin-right:0;}
/* footer */

.footer-2col span a {
	color: #fff !important;
	text-decoration: none;
  }
  
  .sitemap-title {
	  width: 90%;
	  font-size:24px;
	  font-weight: 600;
	  position:relative;
	  color:#00a1a2 !important;
	  text-align:left; 
	  border-bottom:4px solid #00a1a2;
	  padding-bottom: 11px; 
	  padding-left:45px; 
	  margin-bottom:10px;
	  }
  .sitemap-title::before {
	  content: '\f0e8';
	  font-family: 'Font Awesome 5 Free';
	  font-weight: 900;
	  position: absolute;
	  left: 0.3rem;
	  top: 0px;
	  width:33px;
	  height:33px;
  }
  .footer-2col img {
	width: 250px;
	margin-bottom: 10px;
  }
  .footer-2col a {
	  border-radius: 20px;
	  padding: 6px 18px;
	  background: #00a1a2;
	  color: #fff !important;
	  text-decoration: none;
	  margin-right: 12px;
	display: inline;
  }

/* imgを含むaタグのスタイルをリセット */
.footer-2col a:has(img) {
    border-radius: initial;
    padding: initial;
    background: initial;
    color: initial;
    text-decoration: initial;
    margin-right: initial;
    display: initial;
}
  
  .footer-2col img {
	width: 300px;
  }
  .footer-2col {
	  float:left; width:30%; margin-right:14px; padding:8px; text-align:left;
  }
  .footer-2col-2 {
	  float:left; width:60%; margin-right:14px; padding:8px;
  }
  .sitemap-2col {
	width: 97%; float:left; margin-right:16px;
	}
	.sitemap-2col-2 {
		float:left; width:46%; padding:8px;
	}
  .footer-2col span {
  color: #fff;
	  font-size: .8rem;
	  padding: 7px 15px;
	  margin-right: 6px;
	  margin-left: 8px;
	  border-radius: 20px;
	  background: #645601;
	  }
  .footer-2col span a {
	  color: #fff;
  }
  .com-caption {
	color: #000;
	font-size: 1rem;
	margin-bottom: 0;
	padding-left: 8px;
   }

   ul.sitemap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(16px, 4vw, 16px);
    max-width: 1200px;
    margin: 0 auto;
}
   ul.sitemap li {
	width: 84%;
	font-size: 1rem;
	list-style: none;
	padding: 12px 14px 12px 33px;
	border-bottom: 1px dashed #fff !important;
	position: relative;
	display: block;
	text-align: left;
  }
  ul.sitemap li:nth-child(odd) {
	margin-right: 19px;
  }
  ul.sitemap li:before {
	  content: "\f0d7";
	  font-family: 'Font Awesome 5 Free';
	  font-weight: 900;
	  transform: rotate(270deg);
	  color: #00a1a2;
	  position: absolute;
	  left: 6px;
	  top: 9px;
	  width:22px;
	  height:22px;
  }
  ul.sitemap li a {
	color: #000 !important;
	text-decoration: none;
  }

/* add */
.com-copy {
	font-size: 1.2rem;
    font-weight: 600;
    text-align: center;
    line-height: 1.7;
}
.sub-caps {
	color: #fab4ff;
	font-size: 1rem;
    text-align: center;
}

.feature-txt {
	font-family: "Fredericka the Great", serif;
	font-size: 6rem;
    color: #c3c3c3;
	margin-bottom: 55px;
}


ul.feat-title::after {
	content: "";
	display: block;
	clear: both;
  }
  ul.feat-title {
    width: 100%;
    margin: 20px 0 54px;
    display: flex;
    align-items: center; /* 縦中央揃え */
    gap: 23px; /* 要素間の間隔 */
}

ul.feat-title li {
    list-style: none;
}

ul.feat-title li:nth-child(1) {
    color: #022488;
    font-size: 4rem;
    font-weight: 900;
}

ul.feat-title li:nth-child(2) {
    color: #000;
    font-size: 1.2rem;
    padding: 8px;
    background: linear-gradient(to right, #fff 90%, transparent 100%);
    font-weight: 800;
}

.d-build {
	width:100%;
	padding:12px;
	margin-top: 80px;
}
.d-build h2 {
	color: #022488;
	font-weight: 900;
    font-size: 2rem;
}
.left80 {margin-left:80px;}

ul.strong-point-full {
	width: 100%;
	margin:8px 0;
	list-style: none;
	display: flex;
	align-items: center;
	box-shadow: 2px 0px 30px 7px #ccc;
	border-left: 10px #b58800 solid;
	scroll-margin-top: 40vh;
}
ul.strong-point-full:target {
    background-color: #fde4fb;
    border: 2px solid #fee0fc;
    box-shadow: 0 0 10px rgb(197 21 251 / 50%);
    transform: scale(1.02);
}
ul.strong-point {
	width: 95%;
	margin:8px 0;
	background: #fff;
	list-style: none;
	display: flex;
	align-items: center;
    border-left: 10px #b58800 solid;
	box-shadow: 2px 0px 30px 7px #ccc;
}
 ul.strong-point2 {
	margin:30px 0 0 80px;
	list-style: none;
	background: #fff;
	display: flex;
	align-items: center;
	border-left: 10px #b58800 solid;
	box-shadow: 2px 0px 30px 7px #ccc;
}
ul.strong-point::after, ul.strong-point2::after, ul.strong-point-full::after  {
	content: "";
	display: block;
	clear: both;
  }
ul.strong-point li, ul.strong-point2 li, ul.strong-point-full li {
	float: left;
	list-style: none;
}
ul.strong-point li:first-child, ul.strong-point-full li:first-child {
	width:300px;
	height: 200px;
	float: left;
	margin-right: 45px;
	list-style: none;
}
ul.strong-point2 li:first-child {
	width:300px;
	height: 200px;
	float: left;
	margin-right: 45px;
}
ul.strong-point li:nth-child(2), ul.strong-point-full li:nth-child(2) {
	width:66%;
	height: auto;
	float: left;
}
ul.strong-point2 li:nth-child(2) {
	width:64%;
	height: auto;
	float: left;
}
ul.strong-point span, ul.strong-point2 span, ul.strong-point-full span {
	color: #022488;
	font-size:1.5rem;
	font-weight:700;
	margin-bottom: 20px;
	display: block;
}

.circle-wrapper {
	width: 100%;
	max-width: 1200px;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 20px;
	margin-top: 60px;
}

.circle-card {
	position: relative;
	background: #fff;
	width: 330px;
	height: 330px;
	border-radius: 50%;
	overflow: hidden;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: all 0.5s ease;
	border: 5px solid #b58800;
	box-shadow: 0 15px 35px rgba(0, 0, 0, 0.1);
}

.circle-card:hover {
	transform: translateY(-10px);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
}

.circle-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	z-index: 1;
}

/* .circle-card:nth-child(1) .circle-bg {
	background: linear-gradient(135deg, #6e8efb, #a777e3);
}

.circle-card:nth-child(2) .circle-bg {
	background: linear-gradient(135deg, #5ee7df, #b490ca);
}

.circle-card:nth-child(3) .circle-bg {
	background: linear-gradient(135deg, #fd746c, #ff9068);
} */

.circle-content {
	position: relative;
	z-index: 2;
	text-align: center;
	width: 85%;
	padding: 25px 20px;
	/* background-color: rgba(255, 255, 255, 0.9); */
	border-radius: 12px;
	/* backdrop-filter: blur(5px); */
	transition: all 0.3s ease;
}

.circle-card:hover .content {
	background-color: rgba(255, 255, 255, 0.95);
	transform: scale(1.05);
}

.circle-content h2 {
	font-size: 1.5rem;
	margin-bottom: 12px;
	color: #022488;
	font-weight: 600;
}

.circle-content p {
	color: #b58800;
    font-weight: 600;
	font-size: 0.95rem;
	line-height: 1.5;
}

.bold {
	font-size: 1.2rem; margin-top: -20px; font-weight: 800;
}

.care-container {
	width: 100%;
	background: url(http://localhost:8888/chiba/wp-content/uploads/demo-care-1.png) no-repeat;
	background-size: cover;
	background-position: right;
}
.care-wrapper {
	display: flex; 
	margin-top:30px;
}
.care-col1 {
	width: 240px;
    height: 360px;
    background: #ccc;
    margin-right: 30px;
}
.care-col2 {
	padding: 12px;
}
.care-col2 span {
	color: #022488;
	font-weight: 700;
	font-size: 1.3rem;
    margin-bottom: 20px;
    display: block;
}
ul.care-list {
	list-style: none;
	margin-bottom: 43px;
}
ul.care-list li {
	display: inline;
	border:1px solid #000;
	padding: 3px 12px 6px;
	margin-right: 12px;
	border-radius:30px;
	background: #ffd55d;
}
ul.care-list li:nth-last-child(2) {
	margin-right: 0;
}
ul.care-list li:last-child {
	border: none;
	background: none;
}
.icon-style {
	font-size: 2rem;
    color: #022488;
    margin-bottom: 10px;
}

.button-container {
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 60px;
}

.contact-button {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 16px 32px;
	border: none;
	border-radius: 12px;
	font-size: 16px;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	cursor: pointer;
	position: relative;
	overflow: hidden;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
	min-width: 200px;
}

.contact-button::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
	transition: left 0.5s;
}

.contact-button:hover::before {
	left: 100%;
}

.inquiry-button {
	background: linear-gradient(135deg, #022488, #0338b8);
	color: white;
}

.inquiry-button:hover {
	color: #fff;
	background: linear-gradient(135deg, #0338b8, #022488);
	transform: translateY(-2px);
	box-shadow: 0 8px 25px rgba(255, 255, 255, 0.3);
}

.phone-button {
	background: linear-gradient(135deg, #b58800, #d4a000);
	color: white;
}

.phone-button:hover {
	background: linear-gradient(135deg, #d4a000, #b58800);
	transform: translateY(-2px);
	box-shadow: 0 8px 25px rgba(181, 136, 0, 0.3);
}

.contact-button i {
	font-size: 18px;
	transition: transform 0.3s ease;
}

.contact-button:hover i {
	transform: scale(1.1);
}

.contact-button:active {
	transform: translateY(0);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
	.button-container {
		flex-direction: column;
		gap: 16px;
	}
	
	.contact-button {
		min-width: 250px;
		padding: 18px 24px;
	}
}

/* アニメーション効果 */
.contact-button {
	animation: fadeInUp 0.6s ease-out;
}

.phone-button {
	animation-delay: 0.2s;
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.card-container {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 常に3カラム */
    gap: 20px;
    padding: 20px 0;
    min-height: 300px; /* 最小高さを設定（オプション） */
}
.card-image {
    position: relative;
}

.card-date {
    position: absolute;
    top: 8px;
    left: 8px;
    background-color: #fff;
    color: #000;
    padding: 4px 8px;
    font-size: 1rem;
    z-index: 10;
}

.post-card {
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
	position: relative;
}

.post-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.15);
}

.card-image {
    position: relative;
    overflow: hidden;
    height: 200px;
}

.card-thumbnail {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.card-image:hover .card-thumbnail {
    transform: scale(1.05);
}

.card-content {
    padding: 20px;
}

.card-title {
    margin: 0 0 15px 0;
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.4;
	min-height: 90px;
}

.card-title a {
    color: #333;
    text-decoration: none;
    transition: color 0.3s ease;
}

.card-title a:hover {
    color: #00a1a2;
}

.card-button {
    text-align: center;
}

.btn-detail {
    display: inline-block;
    background: #00a1a2;
    color: #fff;
    padding: 10px 20px;
    text-decoration: none;
    border-radius: 4px;
    transition: 0.3s ease;
}

.btn-detail:hover {
    opacity: .86;
}

/* レスポンシブ対応 */
@media (max-width: 1024px) {
    .card-container {
        grid-template-columns: repeat(2, 1fr); /* タブレットサイズでは2カラム */
    }
}

@media (max-width: 768px) {
    .card-container {
        grid-template-columns: 1fr; /* スマートフォンサイズでは1カラム */
        gap: 15px;
    }
    
    .card-image {
        height: 180px;
    }
    
    .card-content {
        padding: 15px;
    }
}

h1.page-title {
	color: #00a1a2;
    font-style: italic;
    font-size: 4.6rem;
    font-family: 'Shippori Mincho';
}
header.page-header {
    position: absolute;
    top: 33%;
    left: 80px;
    z-index: 9;
}

table.company {
    width: 90%;
	margin: 0 auto !important;
    box-shadow: -1px 2px 12px 6px #e2e2e2;
    border-radius: 12px;
}
table.company th {
	color: #000 !important;
    background: #f7f7f7;
 	padding:30px !important;
}
table.company tr:last-child th {
	border: none !important;
}
table.company td {
	padding: 30px !important;
}

.service-wrapper {
	display: flex;
	height: 100vh;
}

/* 左側50% - 画像エリア */
/* 全体のラッパー */
.service-wrapper {
    display: flex;
    height: 100vh; /* min-heightからheightに変更 */
}

.left-area {
    width: 50%;
    background-color: #f0f0f0;
    display: flex; /* 追加 */
}

.left-area img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* 右側50% - リストエリア */
.right-area {
    width: 50%;
    background-color: #ffb5e6;
    display: flex; /* 追加 */
    overflow: hidden; /* はみ出し防止 */
}

.service-list {
    list-style: none;
    width: 100%;
    height: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr 1fr; /* 3行に変更 */
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}

/* 上段の2カラム×2段 */
.service-list li:nth-child(1),
.service-list li:nth-child(2),
.service-list li:nth-child(3),
.service-list li:nth-child(4) {
    /* グリッドで自動配置 */
}

/* 下段の1カラム×2つ */
.service-list li:nth-child(5) {
    grid-column: 1 / -1; /* 全幅 */
}

.service-list li:nth-child(6) {
    grid-column: 1 / -1; /* 全幅 */
}

/* 7番目以降の要素を非表示にする（念のため） */
.service-list li:nth-child(n+7) {
    display: none;
}

/* リンクスタイル */
.service-list a {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    padding: 20px;
    text-decoration: none;
    color: #333;
    background-color: #00a1a2;
    border: .1px solid #ffb5e6;
    transition: all 0.3s ease;
    text-align: left;
    box-sizing: border-box; /* 追加 */
}

.service-list a:hover {
    background-color: #04a7a7;
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

/* タイトルスタイル */
.service-title {
    font-size: 1.14em;
    font-weight: bold;
    margin-bottom: 8px;
    color: #ffd0fb;
}

/* 説明文スタイル */
.service-description {
    font-size: 0.84em;
    color: #fff;
    line-height: 1.4;
}

/* レスポンシブ対応 */
@media (max-width: 480px) {
    .service-wrapper {
        flex-direction: column;
        height: auto;
    }

    .left-area,
    .right-area {
        width: 100%;
    }

    .left-area {
        height: 50vh;
    }

    .right-area {
        overflow: visible; /* モバイルでは制限解除 */
    }

    .service-list {
        grid-template-columns: 1fr;
        grid-template-rows: repeat(6, auto);
        height: auto;
    }

    .service-list li:nth-child(5),
    .service-list li:nth-child(6) {
        grid-column: 1;
    }
}

.btn-wrapper {
    max-width: 1200px;
    margin: 70px auto 0;
    padding: 2rem 1rem;
}

.btn-3col-grid {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
}

.btn-3col {
    flex: 1;
    min-width: 280px;
	border: 1px solid #ffb5e6;
    padding: 2rem;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.btn-3col:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

.btn-3col-title {
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
    color: #333;
}

.btn-3col-button {
    background: transparent;
    color: #fff;
    border: 1px solid #ffb5e6;
    border-radius: 25px;
    padding: 12px 24px;
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
	position: relative;
}
.btn-3col-button2 {
    background: transparent;
    color: #000000;
    border: 1px solid #ffb5e6;
    border-radius: 25px;
    padding: 12px 24px;
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.3s ease;
	display: block;
    margin: 0 auto;
	position: relative;
}
button.btn-3col-button a, button.btn-3col-button2 a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.btn-3col-button:hover {
    background: linear-gradient(135deg, #16c0b2 0%, #02a285 100%);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
}
.btn-3col-button2:hover {
    background: linear-gradient(135deg, rgba(22, 192, 178, 0.8) 0%, rgba(2, 162, 133, 0.8) 100%);
    transform: translateY(-2px);
    opacity: 0.86;
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
}

.btn-3col-button:active {
    transform: translateY(0);
}

/* レスポンシブ対応 */
@media (max-width: 480px) {
    .btn-3col-grid {
        flex-direction: column;
        gap: 1.5rem;
    }
    
    .btn-3col {
        min-width: unset;
    }
    
    .btn-wrapper {
        padding: 1rem;
    }
}

@media (max-width: 992px) and (min-width: 769px) {
    .btn-3col-grid {
        flex-wrap: wrap;
    }
    
    .btn-3col {
        flex-basis: calc(50% - 1rem);
    }
}

@media (min-width: 1200px) {
    .btn-3col-grid {
        gap: 2.5rem;
    }
}

.container-area {
    max-width: 1000px;
    margin: 0 auto;
    display: flex;
    gap: 30px;
    background-color: white;
    padding: 30px;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.area-section {
    flex: 1;
    background-color: #fafafa;
    padding: 25px;
    border-radius: 8px;
    border: 1px solid #e0e0e0;
}

.area-title {
    font-size: 20px;
    font-weight: bold;
    color: #333;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 2px solid #f8b6d1;
    text-align: center;
}

/* グループセクションのスタイル */
.group-section {
    margin-bottom: 20px;
    padding: 15px;
    background-color: white;
    border-radius: 6px;
    border: 1px solid #e8e8e8;
}

.group-section:last-child {
    margin-bottom: 0;
}

.group-title {
    font-size: 16px;
    font-weight: bold;
    color: #555;
    margin-bottom: 12px;
    text-align: center;
    padding-bottom: 6px;
    border-bottom: 1px solid #ddd;
}

.tags-container {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
}

.tag {
    background-color: #00a1a2;
    color: #fff;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.tag:hover {
    background-color: #f591b7;
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    cursor: auto;
}

/* レスポンシブ対応 */
@media (max-width: 480px) {
    .container-area {
        flex-direction: column;
        gap: 20px;
        padding: 20px;
    }
    
    .area-section {
        padding: 20px;
    }
    
    .area-title {
        font-size: 18px;
    }
    
    .group-section {
        padding: 12px;
    }
    
    .group-title {
        font-size: 14px;
    }
    
    .tag {
        font-size: 12px;
        padding: 3px 10px;
    }
}

/* ul.strong-point-full {
	width: 100%;
	margin:8px 0 60px;
	list-style: none;
	display: flex;
	align-items: center;
	box-shadow: 2px 0px 30px 7px #ccc;
	border-left: 10px #f8b6d1 solid;
}
ul.strong-point li, ul.strong-point2 li, ul.strong-point-full li {
	float: left;
	list-style: none;
}
ul.strong-point-full li:first-child {
	width:300px;
	height: 200px;
	float: left;
	margin-right: 45px;
	list-style: none;
}
ul.strong-point-full li:nth-child(2) {
	width:66%;
	height: auto;
	float: left;
	font-size: 1rem;
}
ul.strong-point-full li:nth-child(2) strong {
	font-size:1.18rem;
}
ul.strong-point span, ul.strong-point2 span, ul.strong-point-full span {
	color: #00a1a2;
	font-size:1.5rem;
	font-weight:700;
	margin-bottom: 20px;
	display: block;
} */



ul.strong-point-full {
	width: 100%;
	margin:8px 0 60px;
	list-style: none;
	display: flex;
	align-items: center;
	box-shadow: 2px 0px 30px 7px #ccc;
	border-left: 10px #00a1a2 solid;
	flex-wrap: wrap; /* 追加 */
}

ul.strong-point {
	width: 95%;
	margin: 8px 0;
	background: #fff;
	list-style: none;
	display: flex;
	align-items: center;
	border-left: 10px #00a1a2 solid;
	box-shadow: 2px 0px 30px 7px #ccc;
	flex-wrap: wrap; /* 追加 */
}

ul.strong-point2 {
	margin: 30px 0 0 80px;
	list-style: none;
	background: #fff;
	display: flex;
	align-items: center;
	border-left: 10px #00a1a2 solid;
	box-shadow: 2px 0px 30px 7px #ccc;
	flex-wrap: wrap; /* 追加 */
}

ul.feature-point-full {
	width: 100%;
	margin: 8px 0;
	list-style: none;
	display: flex;
	align-items: center;
	box-shadow: 2px 0px 30px 7px #ccc;
	border-left: 10px #00a1a2 solid;
	flex-wrap: wrap; /* 追加 */
}

ul.strong-point::after, 
ul.strong-point2::after, 
ul.strong-point-full::after, 
ul.feature-point-full::after {
	content: "";
	display: block;
	clear: both;
}

ul.strong-point li, 
ul.strong-point2 li, 
ul.strong-point-full li, 
ul.feature-point-full li {
	list-style: none;
}

/* デスクトップ表示 */
ul.strong-point li:first-child, 
ul.strong-point-full li:first-child, 
ul.feature-point-full li:first-child {
	width: 300px;
	height: 200px;
	margin-right: 45px;
	list-style: none;
	flex-shrink: 0; /* 追加 */
}

ul.strong-point2 li:first-child {
	width: 300px;
	height: 200px;
	margin-right: 45px;
	flex-shrink: 0; /* 追加 */
}

ul.strong-point li:nth-child(2), 
ul.strong-point-full li:nth-child(2), 
ul.feature-point-full li:nth-child(2) {
	flex: 1; /* 変更 */
	height: auto;
	min-width: 0; /* 追加 */
	font-size: 1rem;
	padding-right: 30px;
}

.strong-point-full strong {
    font-size: 1.2rem;
}

ul.strong-point2 li:nth-child(2) {
	flex: 1; /* 変更 */
	height: auto;
	min-width: 0; /* 追加 */
	font-size: 1rem;
}

ul.strong-point span, 
ul.strong-point2 span, 
ul.strong-point-full span {
	color: #00a1a2;
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 20px;
	display: block;
}

/* スマートフォン対応 */
@media screen and (max-width: 480px) {
	.d-build {
		padding: 0;
	}
	ul.strong-point, 
	ul.strong-point2, 
	ul.strong-point-full, 
	ul.feature-point-full {
		flex-direction: column;
		align-items: stretch;
		padding: 20px;
		margin: 8px 0 50px;
	}
	
	ul.strong-point2 {
		margin: 30px 0 0 0; /* 左マージンをリセット */
	}
	
	ul.strong-point li:first-child, 
	ul.strong-point-full li:first-child, 
	ul.feature-point-full li:first-child,
	ul.strong-point2 li:first-child {
		width: 100%;
		height: 200px;
		margin-right: 0;
		margin-bottom: 20px;
	}
	
	ul.strong-point li:nth-child(2), 
	ul.strong-point-full li:nth-child(2), 
	ul.feature-point-full li:nth-child(2),
	ul.strong-point2 li:nth-child(2) {
		width: 100%;
	}
	
	ul.strong-point span, 
	ul.strong-point2 span, 
	ul.strong-point-full span {
		font-size: 1.2rem;
		margin-bottom: 10px;
	}
}

.button-container {
	text-align: center;
  }
  .button-container a{ color: #fff !important; text-decoration:none;}
  
  .contact-btn {
	  font-family: 'Noto Sans JP';
	  font-size: 1.1rem;
	  display: inline-block;
	  padding: 15px 40px;
	  color: #fff;
	  background: linear-gradient(327deg, #82e3ff, #00a1a2);
	  border-radius: 30px;
	  text-decoration: none;
	  font-weight: 500;
	  letter-spacing: 1px;
	  box-shadow: 0 5px 15px rgba(0,0,0,0.2);
	  transition: all 0.3s ease;
  }
  
  .contact-btn:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 20px rgba(0,0,0,0.3);
	color: #fff;
  }

  ul.col2-care {
	display: grid;
	grid-template-columns: minmax(200px, max-content) 1fr;
	grid-template-rows: repeat(3, auto);
	gap: 0px;
	list-style: none !important;
	padding: 0;
	margin: 0;
  }

  ul.col2-care li {
	padding: 20px !important;
  	border-bottom: 1px dashed #ddd;
	  list-style: none !important;
  }

  /* 左列（奇数番目）を縦横中央に配置 */
  ul.col2-care li:nth-child(odd) {
	display: flex;
	align-items: center;    /* 縦方向中央 */
	justify-content: center; /* 横方向中央 */
	background-color: #ffeafb;
	font-weight: bold;
  }
  
  @media (max-width: 980px) {
	ul.col2-care {
	  grid-template-columns: 1fr;
	  grid-template-rows: auto;
	}
	
	ul.col2-care li:nth-child(odd) {
	  justify-content: center;
	  border-bottom: none;
	  font-size: 1.1em;
	}
	
	ul.col2-care li:nth-child(even) {
	  background-color: #fff;
	}
  }
  
  /* 極小画面用 */
  @media (max-width: 480px) {
	ul.col2-care li {
	  padding: 10px 15px !important;
	}
	
	ul.col2-care li:nth-child(odd) {
	  padding: 10px 15px 5px 15px !important;
	}
	
	ul.col2-care li:nth-child(even) {
	  padding: 5px 15px 10px 15px !important;
	}
  }

  table.access {
	margin-bottom: 120px !important;
	border-collapse: collapse;
	width: 100%;
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
  }
  
  table.access th {
	width:200px;
	font-weight: 600 !important;
	text-align: center !important;
	padding: 25px 20px !important;
	background: #f9d0fb;
	position: relative;
	font-size: 1rem;
	letter-spacing: 0.5px;
  }
  table.access tr:last-child th, table.access tr:last-child td {
	border: none;
  }
  table.access tr:first-child td {
	font-size: 1.2rem;
  }
  
  table.access th::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 3px;
	background: rgba(255, 255, 255, 0.3);
  }
  
  table.access td {
	padding: 25px 20px !important;
	border-bottom: 1px solid #f0f0f0;
	transition: background-color 0.3s ease;
	font-size: 1rem;
	line-height: 1.6;
  }
  
  table.access tr:hover td {
	background-color: #f8fdfd;
  }
  
  table.access tr:last-child td {
	border-bottom: none;
  }

  /* 画像コンテナのスタイル */
.voice-image-container {
	width: 100%;
	height: 300px;
	overflow: hidden;
	border-radius: 8px;
	margin-bottom: 16px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  }
  
  .voice-image-container img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform 0.3s ease;
  }
  
  /* ホバーエフェクト（オプション） */
  .voice-image-container:hover img {
	transform: scale(1.05);
  }

  .price-section P {margin: 0;}

  .comTable {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	background: white;
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
	border-radius: 12px;
	overflow: hidden;
	border-collapse: collapse;
  }
  
  .comTable tr {
	border-bottom: 1px solid #e5e7eb;
	transition: background-color 0.3s ease;
  }
  
  .comTable tr:hover {
	background-color: #fef7f7;
  }
  
  .comTable tr:last-child {
	border-bottom: none;
  }
  
  .comTable th {
	border-bottom: #fff !important;
	background: #00a1a2;
	color: white !important;
	font-weight: 600;
	padding: 20px 24px !important;
	text-align: center !important;
	width: 25%;
	vertical-align: middle;
	position: relative;
  }
  
  .comTable th::after {
	content: '';
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	width: 1px;
	background: rgba(255, 255, 255, 0.2);
  }
  
  .comTable td {
	padding: 20px 24px !important;
	color: #374151;
	line-height: 1.6;
	vertical-align: top;
  }
  
  .comTable iframe {
	width: 100%;
	height: 300px;
	border: none;
	border-radius: 8px;
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
	margin-top: 16px;
  }
  
  .comLink a {
	display: inline-flex;
	align-items: center;
	padding: 12px 20px;
	background: #00a1a2;
	color: white;
	text-decoration: none;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 500;
	transition: all 0.3s ease;
	box-shadow: 0 2px 4px rgba(0, 161, 162, 0.2);
  }
  
  .comLink a:hover {
	background: #008586;
	transform: translateY(-1px);
	box-shadow: 0 4px 8px rgba(0, 161, 162, 0.3);
  }
  
  .comLink a::before {
	content: '✉';
	margin-right: 8px;
	font-size: 16px;
  }
  
  .comLink.link01 a {
	background: #00a1a2;
  }
  
  .comLink.link01 a:hover {
	background: #008586;
  }
  
  .comLink.link01 a::before {
	content: '📄';
  }
  
  .topDl {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 20px;
	margin-bottom: 20px;
  }
  
  .topDl > div {
	background: #fef7f7;
	padding: 16px;
	border-radius: 8px;
	border-left: 4px solid #00a1a2;
  }
  
  .topDl dt {
	font-weight: 600;
	color: #00a1a2;
	margin-bottom: 8px;
	padding-bottom: 8px;
	border-bottom: 1px solid #fce7e8;
  }
  
  .topDl dd {
	font-size: 14px;
	color: #4b5563;
	line-height: 1.5;
	margin: 0;
  }
  
  .business-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 16px;
	margin-bottom: 16px;
  }
  
  .business-item {
	background: #fef7f7;
	padding: 16px;
	border-radius: 8px;
	border: 1px solid #b5b5b5;
	border-left: 4px solid #00a1a2;
  }
  
  .business-item dt {
	font-weight: 600;
	color: #00a1a2;
	margin-bottom: 8px;
	padding-bottom: 8px;
	border-bottom: 1px solid #fce7e8;
  }
  
  .business-item dd {
	font-size: 14px;
	color: #4b5563;
	line-height: 1.5;
	margin: 0;
  }
  
  .hospital-note {
	margin-top: 16px;
	padding: 12px;
	background: #fef0ff;
	border-radius: 8px;
	border: 1px solid #b5b5b5;
	border-left: 4px solid #00a1a2;
	font-size: 14px;
	color: #00a1a2;
  }
  
  .info-section {
	margin-bottom: 16px;
  }
  
  .info-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 8px;
	margin-bottom: 8px;
  }
  
  .info-item {
	font-size: 14px;
  }
  
  .info-label {
	font-weight: 600;
	color: #00a1a2;
  }
  
  .member-info {
	background: #fef7f7;
	padding: 16px;
	border-radius: 8px;
	border: 1px solid #b5b5b5;
	border-left: 4px solid #00a1a2;
	margin-bottom: 16px;
  }
  
  .publication-info {
	background: #fef7f7;
	padding: 16px;
	border-radius: 8px;
	border: 1px solid #b5b5b5;
	border-left: 4px solid #00a1a2;
	margin-bottom: 16px;
  }
  
  .organization-info {
	background: #fef7f7;
	padding: 16px;
	border-radius: 8px;
	border: 1px solid #b5b5b5;
	border-left: 4px solid #00a1a2;
  }
  
  .date-note {
	font-size: 12px;
	color: #00a1a2;
	margin-top: 8px;
  }
  
  .section-title {
	font-weight: 600;
	margin-bottom: 8px;
	color: #00a1a2;
  }
  
  @media (max-width: 768px) {
	.comTable {
	  font-size: 14px;
	}
	
	.comTable th,
	.comTable td {
	  padding: 12px 16px;
	}
	
	.comTable th {
	  width: 30%;
	}
	
	.business-grid {
	  grid-template-columns: 1fr;
	}
	
	.info-grid {
	  grid-template-columns: 1fr;
	}
  }

  .privacy-policy-wrapper {
	max-width: 1170px;
	margin: 0 auto;
	padding: 40px 20px;
	line-height: 1.7;
	background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
	min-height: 100vh;
  }
  
  .page-title {
	text-align: center;
	color: #00a1a2;
	font-size: 2.5rem;
	font-weight: 700;
	margin-bottom: 40px;
	position: relative;
	padding-bottom: 20px;
  }
  
  .page-title::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 90%;
	height: 4px;
	background: linear-gradient(90deg, #00a1a2, #ffc0cb);
	border-radius: 2px;
  }
  
  .policy-content {
	color: #444;
	font-size: 1rem;
  }
  
  .policy-intro {
	color: #000;
	padding: 30px;
	border-radius: 15px;
	margin-bottom: 40px;
	box-shadow: 0 8px 32px rgba(0, 161, 162, 0.2);
	position: relative;
	overflow: hidden;
  }
  
  .policy-intro::before {
	content: '';
	position: absolute;
	top: -50px;
	right: -50px;
	width: 100px;
	height: 100px;
	background: rgba(255, 255, 255, 0.1);
	border-radius: 50%;
  }
  
  .policy-section {
	margin-bottom: 40px;
	background: white;
	border-radius: 15px;
	padding: 30px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
	border-left: 5px solid #00a1a2;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .policy-section:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
  }
  
  .policy-section h2 {
	color: #00a1a2;
	font-size: 1.5rem;
	font-weight: 600;
	margin-bottom: 20px;
	position: relative;
	padding-left: 20px;
  }
  
  .policy-section h2::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 8px;
	height: 25px;
	background: linear-gradient(135deg, #00a1a2, #ffc0cb);
	border-radius: 4px;
  }
  
  .policy-section h3 {
	color: #333;
	margin-bottom: 15px;
	margin-top: 25px;
	font-size: 1.2rem;
	font-weight: 500;
	padding-left: 15px;
	border-left: 3px solid #ffc0cb;
  }
  
  .policy-section h4 {
	color: #00a1a2;
	margin-bottom: 10px;
	margin-top: 20px;
	font-size: 1.1rem;
	font-weight: 500;
  }
  
  .policy-section ul {
	margin-bottom: 20px;
	padding-left: 0;
  }
  
  .policy-section li {
	margin-bottom: 8px;
	padding-left: 25px;
	position: relative;
	list-style: none;
  }
  
  .policy-section li::before {
	content: '✓';
	position: absolute;
	left: 0;
	color: #00a1a2;
	font-weight: bold;
	font-size: 1.1rem;
  }
  
  .info-category {
	/* background: linear-gradient(135deg, #ffc0cb10, #ffc0cb20); */
	padding: 25px;
	border-radius: 12px;
	margin-bottom: 20px;
	border: 2px solid #ffc0cb40;
	position: relative;
	overflow: hidden;
  }
  
  .info-category::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 4px;
	background: linear-gradient(90deg, #00a1a2, #ffc0cb);
  }
  
  .info-category h4 {
	color: #00a1a2;
	margin-top: 0;
	margin-bottom: 15px;
	font-size: 1.2rem;
	font-weight: 600;
  }
  
  .info-category li::before {
	content: '●';
	color: #ffc0cb;
  }
  
  .contact-info {
	/* background: linear-gradient(135deg, #00a1a2, #00b5b6); */
	color: #000;
	padding: 30px;
	border-radius: 15px;
	position: relative;
	overflow: hidden;
	box-shadow: 0 8px 32px rgba(0, 161, 162, 0.25);
  }
  
  .contact-info::before {
	content: '';
	position: absolute;
	top: -30px;
	right: -30px;
	width: 80px;
	height: 80px;
	background: rgba(255, 192, 203, 0.2);
	border-radius: 50%;
  }
  
  .contact-info::after {
	content: '';
	position: absolute;
	bottom: -20px;
	left: -20px;
	width: 60px;
	height: 60px;
	background: rgba(255, 255, 255, 0.1);
	border-radius: 50%;
  }
  
  .contact-info p {
	margin-bottom: 8px;
	position: relative;
	z-index: 1;
  }
  
  .contact-info strong {
	color: #000;
	font-size: 1.1rem;
  }
  
  .policy-footer {
	margin-top: 50px;
	padding: 30px;
	background: linear-gradient(135deg, #f8f9fa, #ffffff);
	border-radius: 15px;
	text-align: center;
	color: #666;
	border: 2px solid #ffc0cb20;
	position: relative;
  }
  
  .policy-footer::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 60px;
	height: 4px;
	background: linear-gradient(90deg, #00a1a2, #ffc0cb);
	border-radius: 2px;
  }
  
  .policy-footer p {
	margin-bottom: 5px;
	font-weight: 500;
  }
  
  /* アニメーション効果 */
  @keyframes fadeInUp {
	from {
	  opacity: 0;
	  transform: translateY(30px);
	}
	to {
	  opacity: 1;
	  transform: translateY(0);
	}
  }
  
  .policy-section {
	animation: fadeInUp 0.6s ease-out;
  }
  
  .policy-section:nth-child(even) {
	animation-delay: 0.1s;
  }
  
  .policy-section:nth-child(odd) {
	animation-delay: 0.2s;
  }
  
  /* レスポンシブ対応 */
  @media (max-width: 768px) {
	.privacy-policy-wrapper {
	  padding: 20px 15px;
	}
	
	.page-title {
	  font-size: 1.8rem;
	  margin-bottom: 30px;
	}
	
	.policy-section {
	  padding: 20px;
	  margin-bottom: 25px;
	}
	
	.policy-section h2 {
	  font-size: 1.3rem;
	}
	
	.policy-intro,
	.info-category,
	.contact-info {
	  padding: 20px;
	}
	
	.policy-section li {
	  padding-left: 20px;
	}
  }
  
  @media (max-width: 480px) {
	.page-title {
	  font-size: 1.5rem;
	}
	
	.policy-section {
	  padding: 15px;
	}
	
	.policy-section h2 {
	  font-size: 1.2rem;
	}
	
	.policy-intro,
	.contact-info {
	  padding: 15px;
	}
  }
  
  /* 印刷用スタイル */
  @media print {
	.privacy-policy-wrapper {
	  max-width: none;
	  padding: 0;
	  background: white;
	}
	
	.page-title {
	  color: #000;
	}
	
	.policy-section {
	  box-shadow: none;
	  border: 1px solid #ccc;
	  break-inside: avoid;
	  background: white;
	}
	
	.policy-section h2 {
	  color: #000;
	}
	
	.info-category,
	.policy-intro,
	.contact-info {
	  background: white;
	  border: 1px solid #ccc;
	  break-inside: avoid;
	}
	
	.contact-info {
	  color: #000;
	}
  }
  
  /* ダークモード対応 */
  @media (prefers-color-scheme: dark) {
	.privacy-policy-wrapper {
	  background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%);
	  color: #e0e0e0;
	}
	
	.policy-section {
	  background: #333;
	  color: #e0e0e0;
	}
	
	.policy-footer {
	  background: linear-gradient(135deg, #2d2d2d, #333);
	  color: #ccc;
	}
  }

.event-wrap2col {
	max-width: 900px !important;
}

#omoi {
	margin-top: -80px;
	padding-top: 80px;
}