/*
Theme Name: Twenty Twelve
Theme URI: https://wordpress.org/themes/twentytwelve/
Author: the WordPress team
Author URI: https://wordpress.org/
Description: The 2012 theme for WordPress is a fully responsive theme that looks great on any device. Features include a front page template with its own widgets, an optional display font, styling for post formats on both index and single views, and an optional no-sidebar page template. Make it yours with a custom menu, header image, and background.
Version: 4.3
Tested up to: 6.6
Requires at least: 3.5
Requires PHP: 5.2.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: blog, one-column, two-columns, right-sidebar, custom-background, custom-header, custom-menu, editor-style, featured-images, flexible-header, footer-widgets, full-width-template, microformats, post-formats, rtl-language-support, sticky-post, theme-options, translation-ready, block-patterns
Text Domain: twentytwelve

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.
*/

/* =Notes
--------------------------------------------------------------
This stylesheet uses rem values with a pixel fallback. The rem
values (and line heights) are calculated using two variables:

$rembase:     14;
$line-height: 24;

---------- Examples

* Use a pixel value with a rem fallback for font-size, padding, margins, etc.
	padding: 5px 0;
	padding: 0.357142857rem 0; (5 / $rembase)

* Set a font-size and then set a line-height based on the font-size
	font-size: 16px
	font-size: 1.142857143rem; (16 / $rembase)
	line-height: 1.5; ($line-height / 16)

---------- Vertical spacing

Vertical spacing between most elements should use 24px or 48px
to maintain vertical rhythm:

.my-new-div {
	margin: 24px 0;
	margin: 1.714285714rem 0; ( 24 / $rembase )
}

---------- Further reading

http://snook.ca/archives/html_and_css/font-size-with-rem
http://blog.typekit.com/2011/11/09/type-study-sizing-the-legible-letter/


/* =Reset
-------------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;600&display=swap');
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-style:normal;
font-weight: normal;
font-size: 100%;
vertical-align: baseline;
font-family:Avenir , "Open Sans" , "Helvetica Neue" , Helvetica , Arial , Verdana , Roboto ,"Yu Gothic" , "YuGothic" ,  "Hiragino Kaku Gothic Pro" , "Meiryo UI" , Meiryo , "MS PGothic" , sans-serif;
	
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

html{
	overflow-y: scroll;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

input, textarea{
	margin: 0;
	padding: 0;
}

ol, ul{
	list-style:none;
}


ul.flex,.flex{
	display:-webkit-box;
	display:-ms-box;
	display:-moz-flexbox;
	display:-ms-flexbox;
	display:-moz-flex;
	display:-ms-flex;
	display:flex;
	-moz-box-lines:multiple;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
	-webkit-box-pack: left;
	-ms-flex-pack: left;
	justify-content: left;
}

table{
	border-collapse: collapse; 
	border-spacing:0;
	width:100%;
}

caption, th{
	text-align: left;
}

a:focus {
	outline:none;
}

.clear:after {
	content: "."; 
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

* html .clear {
	height: 1px;
}

.both{
	clear:both;
}

.inline_block {  
	display: inline-block;  
	*display: inline;  
	*zoom: 1;  
}
*{
	-webkit-box-sizing:border-box;
	        box-sizing:border-box;
}
a{
	text-decoration:none;
	color:#525252;
}
a:hover {
	color:#dbbd73;
}
body {
	overflow:hidden;
	background:#fff;
}
div, a, p, h1, h2, h3, h4, h5, h6, span, th, td, li, time, footer, button, label, strong, em, b{
	color: #1a1a1a;
	font-family: "Noto Serif JP", serif;
	font-size:16px;
}
b{font-weight:bold;}
img{
	width: 100%;
	display: block;
	height: auto;
}
.img1 {
    max-width: 700px;
    margin: 0 auto;
}
.grecaptcha-badge {
    position: absolute;
    z-index: -100;
    visibility: hidden;
}
section[class^="index_"]{
}
.width {
	width:80%;
	max-width:1200px;
	margin:0 auto;
}
p{
	margin-bottom:10px;
	letter-spacing:1px;
}
section a, section span, section b, section strong {
	font-size:100%;
}
.mt10 {margin-top:10%!important;}
.mt8 {margin-top:8%!important;}
.mt5 {margin-top:5%!important;}
.mt3 {margin-top:3%!important;}
.mt0 {margin-top:0%!important;}
.mb5 {margin-bottom:5%!important;}
.mb0 {margin-bottom:0%!important;}
.mb3 {margin-bottom:3%!important;}
.mb8 {margin-bottom:8%!important;}
.mb10 {margin-bottom:10%!important;}
.mb15 {margin-bottom:15%!important;}
.mb20 {margin-bottom:20%!important;}
ul.li-mb10 > li {
    margin-bottom: 10%;
}

div.floatr,div.floatl {
    margin: 3% auto;
}
.floatr p.float {
    float: right;
    margin: 0 0 10px 3%;
    width: 47%;
}
.floatl p.float {
    float: left;
    margin: 0 3% 10px 0;
    width: 47%;
}
.floatr p.float.fi_small, .floatl p.float.fi_small {
    width: 30%;
}

span.bu {
	border-bottom:1px solid;
	font-weight:600;
	font-size:100%;
}
span.bo {
	font-size:100%;
	font-weight:600;
}
span.bbig{
	font-weight:bold!important;
	font-size:120%!important;
}
span.yellow {
	color:#dbbd73;
}
span.blown {
	color:#b4a899;
}
span.gray {
	color:#707070;
}
span.green {
	color:#1e4727;
}
span.yb {
	background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(0%, #fdf8eb));
    background: -o-linear-gradient(transparent 60%, #fdf8eb 0%);
    background: linear-gradient(transparent 60%, #fdf8eb 0%);
}
.center {
	text-align:center!important;
	margin: 0 auto;
}
.right {
	text-align:right!important;
	margin: 0 0 0 auto;
}
.left {
	text-align:left!important;
	margin: 0 auto 0 0;
}
.ib {
	display:inline-block!important;
}
.small {
	font-size:80%!important;
}

@-webkit-keyframes fadein {
	from {opacity: 0;}
	to {opacity: 1;}
}
@keyframes fadein {
	from {opacity: 0;}
	to {opacity: 1;}
}
@-webkit-keyframes fadein2 {
	from {opacity: 1;}
	to {opacity: 0;display:none;visibility: hidden;}
}
@keyframes fadein2 {
	from {opacity: 1;}
	to {opacity: 0;display:none;visibility: hidden;}
}
@-webkit-keyframes fadeinrl {
	from {
		opacity: 0;
		-webkit-transform: translateX(20px);
		        transform: translateX(20px);
	}
	to {
		opacity: 1;
		-webkit-transform: translateX(0);
		        transform: translateX(0);
	}
}
@keyframes fadeinrl {
	from {
		opacity: 0;
		-webkit-transform: translateX(20px);
		        transform: translateX(20px);
	}
	to {
		opacity: 1;
		-webkit-transform: translateX(0);
		        transform: translateX(0);
	}
}
@-webkit-keyframes fadeinlr {
	from {
		opacity: 0;
		-webkit-transform: translateX(-20px);
		        transform: translateX(-20px);
	}
	to {
		opacity: 1;
		-webkit-transform: translateX(0);
		        transform: translateX(0);
	}
}
@keyframes fadeinlr {
	from {
		opacity: 0;
		-webkit-transform: translateX(-20px);
		        transform: translateX(-20px);
	}
	to {
		opacity: 1;
		-webkit-transform: translateX(0);
		        transform: translateX(0);
	}
}
@-webkit-keyframes fadeinbt {
	from {
		opacity: 0;
		-webkit-transform: translateY(20px);
		        transform: translateY(20px);
	}
	to {
		opacity: 1;
		-webkit-transform: translateY(0);
		        transform: translateY(0);
	}
}
@keyframes fadeinbt {
	from {
		opacity: 0;
		-webkit-transform: translateY(20px);
		        transform: translateY(20px);
	}
	to {
		opacity: 1;
		-webkit-transform: translateY(0);
		        transform: translateY(0);
	}
}
@-webkit-keyframes fadeintb {
	from {
		opacity: 0;
		-webkit-transform: translateY(-20px);
		        transform: translateY(-20px);
	}
	to {
		opacity: 1;
		-webkit-transform: translateY(0);
		        transform: translateY(0);
	}
}
@keyframes fadeintb {
	from {
		opacity: 0;
		-webkit-transform: translateY(-20px);
		        transform: translateY(-20px);
	}
	to {
		opacity: 1;
		-webkit-transform: translateY(0);
		        transform: translateY(0);
	}
}
@-webkit-keyframes loop {
  0% {
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    transform: translateX(-100%);
  }
}
@keyframes loop {
  0% {
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    transform: translateX(-100%);
  }
}
@-webkit-keyframes loop2 {
  0% {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
    -ms-transform: translateX(-200%);
    transform: translateX(-200%);
  }
}
@keyframes loop2 {
  0% {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
    -ms-transform: translateX(-200%);
    transform: translateX(-200%);
  }
}
@-webkit-keyframes loop3 {
  0% {
    -webkit-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%);
  }
}
@keyframes loop3 {
  0% {
    -webkit-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%);
  }
}
@-webkit-keyframes loop4 {
  0% {
    -webkit-transform: translateX(-200%);
    -ms-transform: translateX(-200%);
    transform: translateX(-200%);
  }
  to {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
@keyframes loop4 {
  0% {
    -webkit-transform: translateX(-200%);
    -ms-transform: translateX(-200%);
    transform: translateX(-200%);
  }
  to {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}

.fadein{
	opacity:0;
	-webkit-transition : all 3s;
	-o-transition : all 3s;
	transition : all 3s;
}
.downup .fadein {
	opacity : 0;
	-webkit-transform : translate(0, 50px);
	    -ms-transform : translate(0, 50px);
	        transform : translate(0, 50px);
	-webkit-transition : all 800ms;
	-o-transition : all 800ms;
	transition : all 800ms;
}
.updown .fadein {
	opacity : 0;
	-webkit-transform : translate(0, -50px);
	    -ms-transform : translate(0, -50px);
	        transform : translate(0, -50px);
	-webkit-transition : all 800ms;
	-o-transition : all 800ms;
	transition : all 800ms;
}
.fadeinrl .fadein {
	opacity : 0;
	-webkit-transform : translate(80px, 0);
	    -ms-transform : translate(80px, 0);
	        transform : translate(80px, 0);
	-webkit-transition : all 800ms;
	-o-transition : all 800ms;
	transition : all 800ms;
}
.fadeinlr .fadein {
	opacity : 0;
	-webkit-transform : translate(-80px, 0);
	    -ms-transform : translate(-80px, 0);
	        transform : translate(-80px, 0);
	-webkit-transition : all 800ms;
	-o-transition : all 800ms;
	transition : all 800ms;
}
.fadein.scrollin {
	opacity : 1;
	-webkit-transform : translate(0, 0);
	    -ms-transform : translate(0, 0);
	        transform : translate(0, 0);
}

ul[class^="col2_"] > li {
    width: 48%;
    margin-right: 4%;
    margin-bottom: 3%;
}
ul[class^="col3_"] > li {
    width: 30%;
    margin-right: 5%;
    margin-bottom: 3%;
}
ul[class^="col2_"] > li:nth-child(even), ul[class^="col3_"] > li:nth-child(3n){
    margin-right: 0;
}

/*------------------------------------*\
    ヘッダー＆フッダー00
\*------------------------------------*/


.menu {
    background: #ffffff91;
    position: absolute;
    width: 100%;
    left: 0;
    top: 0;
    z-index: 10;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.menu > div {
}
.menu > div a {
    padding: 10px;
    display: block;
    width: 233px;
}
.menu > nav {
    text-align: right;
    vertical-align: top;
}
.menu > nav > ul > li {
    display: inline-block;
    vertical-align: top;
    text-align: center;
    position: relative;
}
.menu > nav > ul > li a {
    display: block;
    padding: 28.5px 10px;
}
.menu > nav > ul > li a:hover {
	color:#dbbd73;
}
.menu > nav > ul > li > a:hover {
	color:#fff;
}
.menu > nav > ul > li ul {
    height: 0;
    position: absolute;
    left: 0;
    right: 0;
    top: 65px;
    overflow: hidden;
    -webkit-transition: 0.2s;
    -o-transition: 0.2s;
    transition: 0.2s;
    opacity: 0;
    z-index: 1;
    border-top:2px solid #525252;
}
.menu > nav > ul > li ul::before {
    content:"";
    position: absolute;
    width: 100%;
    height: 0;
    background: #fff;
    top: 0;
    left: 0;
    z-index: -1;
    opacity: 0;
    -webkit-transition: 0.2s;
    -o-transition: 0.2s;
    transition: 0.2s;
}
.menu > nav > ul > li ul a {
    padding: 10px 0;
}
.menu > nav > ul > li:hover ul {
    height: auto;
    opacity:1;
    padding:10px 0;
}
.menu > nav > ul > li:hover ul::before {
    height:100%;
    opacity:1;
}
.menur {
    display: none;
}

section.footer {
    margin-top: 10%;
}
section.footer div {
    background: #dbbd73;
    text-align: center;
    margin: 5% auto 0;
    padding: 3% 2% 2%;
}
ul.sitemap {
    margin-bottom: 2%;
}
ul.sitemap li {
    display: inline-block;
}
ul.sitemap li a {
    color: #fff;
    padding: 10px;
    display: block;
}
ul.sns {
}
ul.sns li {
    display: inline-block;
    width: 50px;
    margin-right: 10px;
}
ul.sns li:last-child {
    margin-right: 0;
}
ul.sns li a {
    display: block;
    padding: 6px;
}
ul.sns li a:hover {
	-webkit-filter: brightness(0);
	        filter: brightness(0);
}
footer#colophon {
    text-align: center;
    background: #dbbd73;
    color: #fff;
    font-size: 13px;
    padding: 10px 0;
}
footer#colophon br {
    display: none;
}

/*------------------------------------*\
    トップページ00
\*------------------------------------*/

.ttl-logo1 {
    width: 40%;
    max-width: 350px;
    margin: 0 auto 20px;
}

.ttl1 {
    text-align: center;
    color: #525252;
    font-size: 20px;
    letter-spacing: 3px;
}
.ttl1 span {
    display: block;
    text-transform: uppercase;
    margin-bottom: 30px;
    font-size: 40px;
    letter-spacing: 20px;
    font-weight: 600;
    padding-left: 20px;
}
.ttl2 {
    text-align: left;
    margin: 8% auto 5%;
    font-size: 20px;
    padding-bottom: 20px;
    position: relative;
}
.ttl2::before {
    content:"";
    width: 100%;
    height: 1px;
    background: -o-linear-gradient(45deg, #dbbd73, transparent);
    background: linear-gradient(45deg, #dbbd73, transparent);
    position: absolute;
    bottom: 0;
    right: 0;
}
.ttl2 span {
    display: inline-block;
    color: #dbbd73;
    font-size: 40px;
    letter-spacing: 10px;
    margin-right: 5%;
}
.ttl3 {
    padding: 10px;
    font-size: 23px;
    margin: 5% auto 20px;
    border: 1px solid #b4a999;
    position: relative;
    font-weight: 600;
    overflow: hidden;
}
.ttl3::after {
	content:"";
	background: #b4a999;
	width: 30px;
	height: 30px;
	position: absolute;
	left: -15px;
	top: -15px;
	-webkit-transform: rotate(45deg);
	    -ms-transform: rotate(45deg);
	        transform: rotate(45deg);
}
.ttl4 {
    padding-left: 5%;
    font-size: 20px;
    position: relative;
    padding-bottom: 20px;
    margin-bottom: 3%;
}
.ttl4::before {
    content:"";
    width: 3%;
    height: 5px;
    background: #b4a999;
    position: absolute;
    bottom: 0;
    left: 0;
}
.ttl4 span:first-child {
    display: block;
    color: #b4a999;
    font-size: 40px;
    letter-spacing: 10px;
    margin-left: -5%;
    margin-bottom: 10px;
}
.ttl5 {
    color: #dbbd73;
    font-size: 20px;
    font-weight: 600;
    margin: 20px auto 10px;
}
.ttl6 {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 15px;
    text-align: center;
}
.ttl6 i {
    display: block;
    font-size: 25px;
    margin-bottom: 10px;
}
.ttl6 span {
    display: block;
    color: #dbbd73;
    letter-spacing: 5px;
    font-size: 30px;
    margin-bottom: 10px;
}
.ttl7 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 5%;
    -webkit-box-pack: left;
        -ms-flex-pack: left;
            justify-content: left;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 20px 20px 20px 10px;
	position:relative;
}
.ttl7::before {
	content:"";
	border: 1px solid #b4a999;
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: -2;
	left: 0;
	top: 0;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
.ttl7 > span:first-child {
    color: #fff;
    font-size: 25px;
    position: relative;
    display: inline-block;
    min-width: -webkit-fit-content;
    min-width: -moz-fit-content;
    min-width: fit-content;
    margin-right: 50px;
}
.ttl7 > span:first-child::before {
    content:"";
    background:#b4a999;
    width: 150px;
    height: 150px;
    border-radius: 50%;
    position: absolute;
    z-index: -1;
    top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
      -ms-transform: translateY(-50%) translateX(-50%);
          transform: translateY(-50%) translateX(-50%);
    margin: auto;
}
.ttl7 > span:nth-child(2){
    font-size: 23px;
}
.ttl7 > span:nth-child(2) span {
    background: #dbbd73;
    color:#fff;
    padding: 0 3px;
}
.ttl8 {
    text-align: center;
    font-size: 20px;
    padding-bottom: 10px;
    border-bottom: 1px solid #b4a999;
}
.ttl8 span {
    display: block;
    font-size: 80%;
}
.ttl9 {
    font-size: 23px;
    font-weight: bold;
    margin-bottom: 15px;
}
.ttl9 i {
    font-size: 150%;
    vertical-align: bottom;
}
.ttl10 {
    font-size: 35px;
    letter-spacing: 3px;
}
.ttl_recommend {
    width: 70%;
    margin-bottom: 5%;
    max-width: 230px;
}
p.icon1 {
    text-align: center;
    font-size: 100px;
    margin: 5% auto;
}
p.img_small {
    width: 30%;
    margin: 0 auto 10px;
}

p.link1 a,p.link1a a {
    display: inline-block;
    background: #dbbd73;
    color: #fff;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 3% auto;
    padding: 20px 10px;
    min-width: 280px;
    text-align: center;
}
p.link1 a::after, p.link1a a::after {
    content: "\03e";
    padding-left: 10px;
}
p.link1 a:hover {
    background: #667b9d;
}
p.link1a a {
	background:#707070;
}
p.link1a a:hover {
    background: #dbbd73;
}

ul.link2 {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 5% auto;
}
ul.link2 li {
    margin: 0 2% 1% 0;
    max-width: 46%;
}
ul.link2 li:last-child {
	margin-right:0;
}
ul.link2 li a {
    display: block;
    background: #dbbd73;
    padding: 10px 0;
    text-align: center;
    min-width: 200px;
}
ul.link2 li a img {
    width: 35px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 8px;
}
ul.link2 li a span {
    display: inline-block;
    color: #fff;
    vertical-align: middle;
}
ul.link2 li a:hover {
    background: #707070;
}

ul.link3 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 3% auto;
}
ul.link3 li {
    width: 30%;
    margin-right: 5%;
    text-align: center;
}
ul.link3 li:last-child {
    margin-right: 0;
}
ul.link3 li a {
    display: block;
    background: #dbbd73;
    padding: 20px 40px 20px 10px;
    position: relative;
    color: #fff;
}
ul.link3 li:nth-child(even) a {
    background: #667b9d;
}
ul.link3 li a br {display:none;}
ul.link3 li a i {
    position: absolute;
    font-size: 20px;
    right: 20px;
    top: 0;
    bottom: 0;
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
    margin: auto;
}
ul.link3 li a:hover {
    background: #707070;
}
ul.link3 li a:hover i {
    right:15px;
}

p.by {
    position: relative;
    margin: 0;
}
section.main {
    position: relative;
}
section.main::before {
    content: "";
    width: 100%;
    height: 70%;
    position: absolute;
    left: 0;
    bottom: 0;
    background: -webkit-gradient(linear, left bottom, left top, color-stop(60%, #fff), to(#ffffff00));
    background: -o-linear-gradient(bottom, #fff 60%, #ffffff00);
    background: linear-gradient(0deg, #fff 60%, #ffffff00);
    opacity:0.8;
}
section.main ul li {
    width: calc(100% / 3);
}
section.main ul li:first-child {
    width: 100%;
    max-height: 60vh;
    overflow: hidden;
}
section.main div {
    position: absolute;
    bottom: 3%;
    left: 0;
    right: 0;
    text-align: center;
}
section.main div p:first-child {
    font-size: 40px;
    letter-spacing: 10px;
    margin-bottom: 30px;
    -webkit-filter: drop-shadow(2px 1px 1px #fff);
            filter: drop-shadow(2px 1px 1px #fff);
    font-weight: 600;
}
section.main div h1 {
    letter-spacing: 4px;
}

section.index1 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
}
.index1a {
    width: 90%;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 8% auto 5%;
}
.index1a > p:first-child {
    position: absolute;
    font-size: 130px;
    color: #707070;
    left: 30px;
    top: -100px;
    z-index: 1;
}
.index1a p.by {
    width: 40%;
}
.index1a p.by img, .index1b > p.by img, .index1c p.by img {
    position: absolute;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
}
.index1a h2, .index1b h2,.index1c h2 {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    font-weight: 600;
    font-size: 35px;
    letter-spacing: 10px;
    margin: 1% 3%;
}
.index1a div {
    width: calc(54% - 101px);
}
.index1b {
    width: 57%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-right: 3%;
    position: relative;
}
.index1b > p:first-child {
    position: absolute;
    font-size: 130px;
    color: #707070;
    left: 30px;
    top: -100px;
    z-index: 1;
}
.index1b > p.by {
    width: 35%;
}
.index1b div {
    width: calc(59% - 50.5px);
}
.index1b div p.by {
    margin-top: 8%;
}
.index1c {
    width: 40%;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.index1c > p:first-child {
    font-size: 130px;
    color: #707070;
    margin-top: -100px;
    width: 150px;
}
.index1c > p.by {
    width: calc(100% - 150px);
    margin-top: -45px;
    height: 450px;
    margin-bottom: 5%;
}
.index1c h2 {
    position: absolute;
    left: 0;
    margin: 0;
    top: 80px;
}

.sentence p {
    line-height:28px;
}

section.back_yellow {
    position: relative;
    padding-bottom: 5%;
}
section.back_yellow::before {
    content: "";
    width: 80%;
    max-width: 800px;
    position: absolute;
    background: #fdf8eb;
    height: 90%;
    z-index: -1;
    left: 0;
    right: 0;
    margin: auto;
    bottom: 0;
}
section.back_texture {
    position: relative;
    padding: 5% 0 3%;
}
section.back_texture::before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: url(http://llc-correct.com/wp-content/uploads/2024/10/back1.webp)no-repeat center / cover;
    z-index: -1;
    opacity: 0.4;
}

.loop {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row nowrap;
    flex-flow: row nowrap;
    overflow: hidden;
    width: 100%;
    padding: 10px 0;
}
.loop ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row nowrap;
    flex-flow: row nowrap;
    width: 200%;
    margin: 0;
    padding: 0;
}
.loop ul:first-child {
    -webkit-animation: loop 50s -25s linear infinite;
    animation: loop 50s -25s linear infinite;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    will-change: transform;
}
.loop ul + ul {
    -webkit-animation: loop2 50s  linear infinite;
    animation: loop2 50s linear infinite;
}
.loop:hover ul{
	-webkit-animation-play-state: paused !important;
	        animation-play-state: paused !important;
}
.loop ul li{
	display: inline-block;
	width: calc(100vw / 5);
	list-style: none;
	text-align: center;
	position: relative;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border-right: 20px solid #ddd0;
}
.loop ul li a {
    display: block;
    position: relative;
}
.loop ul li a::before {
    content: "";
    width: 100%;
    padding-top: 100%;
    display: block;
}
.loop ul li a img {
    width: 100%;
    height: 100%;
    position: absolute;
    -o-object-fit: cover;
       object-fit: cover;
    top: 0;
}
section.back_texture div.loop:nth-of-type(2) ul:first-child {
            -webkit-animation: loop3 50s -25s linear infinite;
                    animation: loop3 50s -25s linear infinite;
}
section.back_texture div.loop:nth-of-type(2) ul + ul {
            -webkit-animation: loop4 50s linear infinite;
                    animation: loop4 50s linear infinite;
}
section.index2 {
    position: relative;
    margin: -3% auto 10%;
}
section.index2::before {
    content: "";
    width: 100%;
    height: 192px;
    position: absolute;
    background: #ddd;
    z-index: -1;
    bottom: -30px;
}
section.index2 > div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
}
section.index2 > div > p::before {
    content:"";
    width: 100%;
    padding-top: 120%;
    display: block;
}
section.index2 > div > p:first-child {
    width: calc(50% - 230px);
    margin-right: 3%;
    position: relative;
}
section.index2 > div > p:nth-child(2) {
    width: calc(44% - 230px);
    margin-right: 3%;
    position: relative;
}
section.index2 > div > p img {
    position: absolute;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    top: 0;
    -webkit-filter: grayscale(1);
            filter: grayscale(1);
}
section.index2 > div div {
    width: 460px;
}
section.index2 > div div p {
    font-size: 28px;
    font-weight: 600;
    position: relative;
}

.index3 {
    text-align: center;
    margin: 3% auto;
    padding: 5% 0;
    background: url(http://llc-correct.com/wp-content/uploads/2024/10/mocup.webp)no-repeat center / cover;
}
.index3 div.width {
    max-width: 800px;
    background: #ffffffd1;
    padding: 3% 3% 0px;
}


/*------------------------------------*\
    アーカイブ00
\*------------------------------------*/





/*------------------------------------*\
    下層ページ00
\*------------------------------------*/

section.header {
    background: url(http://llc-correct.com/wp-content/uploads/2024/10/back2.webp)no-repeat center / cover;
    padding: 80px 0 8%;
    overflow: hidden;
}
.ttl-page {
    display: block;
    margin-top: 10%;
    text-align: center;
    font-size: 20px;
    letter-spacing: 3px;
    font-weight: 600;
    position: relative;
    z-index: 1;
    padding: 3% 0;
}
.ttl-page span {
    display: block;
    text-transform: uppercase;
    margin-bottom: 30px;
    font-size: 40px;
    letter-spacing: 20px;
    font-weight: 600;
}
.ttl-page::before {
    content: "";
    width: 100%;
    height: 100%;
    background: #ffffff8f;
    position: absolute;
    z-index: -1;
    left: 0;
    top: 0;
}
section.bread {
    margin-bottom:3%;
}
section.bread li {
    display: inline-block;
    font-size: 14px;
}
section.bread li::after {
    content:"/";
    padding: 0 10px;
}
section.bread li:last-child::after {
    display:none;
}
section.bread li a {
    display: inline-block;
    padding: 12px 0;
}


section.contact-f, p.cf-txt {
    max-width: 850px;
    margin: 0 auto;
}
section.contact-f th p, section.contact-f td p:last-child {
    margin:0;
}
section.contact-f table {
    border-collapse: separate;
    border-spacing: 0 10px;
}
section.contact-f table th {
    background: linear-gradient(90deg, #dbbd7361, transparent);
    text-align: center;
    width: 200px;
    padding: 20px 0;
    vertical-align: top;
}
section.contact-f table th span {
    font-size: 80%;
    color: #cc1c1c;
}
section.contact-f table td {
    padding: 20px 0 20px 20px;
    vertical-align: middle;
}
section.contact-f table td span.rei {
    display: block;
    margin-top: 3px;
    font-size: 15px;
}
section.contact-f table td span.wpcf7-list-item {
    margin: 0 1em 0 0;
    line-height: 28px;
    letter-spacing: 1px;
}
section.contact-f table td span.wpcf7-acceptance span.wpcf7-list-item, section.contact-f table td span.acceptance-001 span.wpcf7-list-item {
    margin: 0;
}
div.wpcf7 td span.wpcf7-list-item-label {
    cursor: pointer;
}
section.contact-f table td span.wpcf7-form-control-wrap {
}
section.contact-f table td input.wpcf7-text, section.contact-f table td textarea.wpcf7-textarea {
    border: 1px solid #b6b6b6;
    background: #f5f5f5;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
section.contact-f table td input.wpcf7-text {
    width: 80%;
    max-width: 400px;
    height: 35px;
}
section.contact-f table td textarea.wpcf7-textarea {
    width: 100%;
}
section.contact-f p span.wpcf7-spinner {
    vertical-align: sub;
}
section.contact-f p input.wpcf7-form-control.wpcf7-submit {
    padding: 10px 30px;
    background: #dbbd73;
    -webkit-transition: 0.2s ease-in-out;
    -o-transition: 0.2s ease-in-out;
    transition: 0.2s ease-in-out;
    font-size: 18px;
    font-weight: 500;
    margin-top: 50px;
    margin-left: 72px;
    color: #fff;
    font-family: "Noto Serif JP", serif;
    border-radius: 5px;
    min-width: 200px;
}
section.contact-f p input.wpcf7-form-control.wpcf7-submit:hover {
    background: #707070;
    color: #fff;
}
section.contact-f form > p {
    text-align: center;
}

table.co-info {
    border-collapse: separate;
    border-spacing: 0 10px;
}
table.co-info tr {
    -webkit-box-shadow: 2px 2px 5px 0px rgb(0 0 0 / 12%);
            box-shadow: 2px 2px 5px 0px rgb(0 0 0 / 12%);
}
table.co-info th {
    background: #dbbd73;
    width: 250px;
    text-align: center;
    color: #fff;
    padding: 20px 0;
}
table.co-info td {
    padding: 20px;
}
ul.sitemap1 {
}
ul.sitemap1 > li {
    width: 48%;
    vertical-align: top;
    margin-right: 4%;
    border-bottom: 1px solid #707070;
}
ul.sitemap1 > li:nth-child(even) {
    margin-right: 0;
}
ul.sitemap1 > li > a {
    display: block;
    padding: 10px;
    position: relative;
}
ul.sitemap1 > li > a::after {
    content: "\03e";
    position: absolute;
    right: 10px;
}
ul.sitemap1 > li li a {
    padding: 0 10px 10px;
    display: block;
    font-size: 15px;
}
ul.sitemap1 > li li a::before {
    content: "-";
    padding-right: 10px;
}

ul.listc {
    text-align: left;
    margin: 3% auto;
}
ul.listc li {
    position: relative;
    padding-left: 1.5rem;
    letter-spacing: 0.5px;
    line-height: 28px;
}
ul.listc li i {
    position: absolute;
    left: 3px;
    top: 6px;
}

ul.flow {}
ul.flow > li {
    margin-bottom: 8%;
    position: relative;
}
ul.flow > li::before {
    content: "";
    width: 90%;
    height: 80%;
    position: absolute;
    background: #f6f1eb;
    z-index: -1;
    right: -3%;
    top: 5%;
}
ul.flow > li:nth-child(even)::before {
    background: #eee;
}

.box-gray {
    margin: 3% auto;
    background: #f6f1eb;
    padding: 3%;
}
.box_yellow {
	margin: 3% auto;
    background: #fff8e6;
    padding: 3%;
}









@media screen and (max-width: 1000px) {
.width {
	width:90%;
}
p {
	font-size:15.5px;
	margin-bottom:8px;
}

/*------------------------------------*\
    ヘッダー＆フッダー1000
\*------------------------------------*/
.menu nav {
    display: none;
}
div.menur {
    display: block;
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 99;
}
.r-btn {
    position: fixed;
    top: 10px;
    right: 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 60px;
    width: 60px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    z-index: 10000;
    background-color: #dbbd73;
}
.r-btn span,
.r-btn span:before,
.r-btn span:after {
    content: '';
    display: block;
    height: 3px;
    width: 25px;
    border-radius: 3px;
    background-color: #fff;
    position: absolute;
    -webkit-transition: 0.2s;
    -o-transition: 0.2s;
    transition: 0.2s;
}
.r-btn span:before {
    bottom: 8px;
}
.r-btn span:after {
    top: 8px;
}
#label1:checked ~ .r-btn span {
    background-color: #fff0;
}
#label1:checked ~ .r-btn span::before {
    bottom: 0;
    -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
            transform: rotate(45deg);
}
#label1:checked ~ .r-btn span::after {
    top: 0;
    -webkit-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
            transform: rotate(-45deg);
}
#label1 {
    display: none;
}
.hidden_box .hidden_show {
    height: 0;
    padding: 0 80px 0 10px;
    overflow: hidden;
    -webkit-transition: 0.8s;
    -o-transition: 0.8s;
    transition: 0.8s;
    width: 100%;
    -webkit-transform: translateY(-100%);
    -ms-transform: translateY(-100%);
    transform: translateY(-100%);
    text-align: center;
    -webkit-box-shadow: 0px 2px 8px 0px rgb(0 0 0 / 35%);
    box-shadow: 0px 2px 8px 0px rgb(0 0 0 / 35%);
    max-height: 100vh;
}
.hidden_show p.ttl-logo {
	opacity:0;
	width: 70%;
	margin:0 auto 5%;
	max-width: 300px;
}
.hidden_show ul.nav1 {
    height: 0;
    padding: 0;
    overflow: hidden;
    width: 100%;
    margin: 0 auto;
    max-width: 600px;
}
.hidden_box input:checked ~ .hidden_show {
    padding: 20px 80px 30px 10px;
    height: auto;
    opacity: 1;
    margin: 0 auto;
    -webkit-transform: translateY(0%);
    -ms-transform: translateY(0%);
    transform: translateY(0%);
    -webkit-box-sizing:border-box;
    box-sizing:
    border-box;
    overflow: scroll;
    background: #707070;
}
.hidden_box input:checked ~ .hidden_show p.ttl-logo {
	opacity:1;
}
.hidden_box input:checked ~ .hidden_show ul.nav1 {
	opacity: 1;
	height: auto;
}
.hidden_show ul.nav1 > li{
    border-bottom: 1px solid #fff;
}
.hidden_show ul.nav1 > li:last-child{
    border-bottom: unset;
}
.hidden_show ul.nav1 > li > a {
    color: #fff;
    padding: 10px 0;
    display: block;
    font-size: 110%;
    font-weight: 600;
}
.hidden_show ul.nav1 > li li a {
    padding-bottom: 10px;
    display: block;
    color: #fff;
}
.hidden_show ul.nav1 > li li a::before {
    content: "-";
    display: inline-block;
    padding-right: 15px;
}





/*------------------------------------*\
    トップページ1000
\*------------------------------------*/

.ttl1, .ttl5, .ttl8 {
    font-size: 18px;
}
.ttl1 span {
    font-size: 35px;
    letter-spacing: 18px;
    margin-bottom: 20px;
    padding-left: 15px;
}
.ttl2, .ttl4 {
    font-size: 18px;
    padding-bottom: 15px;
}
.ttl2 span, .ttl4 span:first-child {
	font-size:35px;
}
.ttl3, .ttl7 > span:nth-child(2), .ttl9 {
    font-size: 20px;
}
.ttl4::before {
    height: 3px;
}
.ttl6 {
    font-size: 17px;
    margin-bottom: 10px;
}
.ttl6 i {
    font-size: 23px;
    margin-bottom: 5px;
}
.ttl6 span {
    font-size: 25px;
    margin-bottom: 5px;
}
.ttl7 {
    padding: 15px 15px 15px 5px;
}
.ttl7 > span:first-child {
    font-size: 23px;
    margin-right: 40px;
}
.ttl7 > span:first-child::before {
    width: 130px;
    height: 130px;
}
.ttl10 {
    font-size: 30px;
}
p.icon1 {
    font-size: 80px;
}

ul.link3 li {
    width: 32%;
    margin-right: 2%;
}

.index1a {
    width: 94%;
}
.index1a > p:first-child,.index1b > p:first-child {
    font-size: 100px;
    top: -80px;
}
.index1a h2, .index1b h2, .index1c h2 {
    font-size: 30px;
}
.index1a div {
	width: calc(54% - 87px);
}
.index1b {
    width: 97%;
    margin-top: 5%;
}
.index1b div {
    width: calc(59% - 44px);
}
.index1c {
    width: 100%;
}
.index1c > p:first-child {
    margin: 0 3% 0;
    font-size: 100px;
    width: 110px;
}
.index1c > p.by {
    margin-top: 5%;
    width: calc(94% - 110px);
    height: 380px;
}
.index1c h2 {
    top: 150px;
    left: 3%;
}
.index1c div {
    width: 94%;
    margin: 0 auto;
    height: auto;
}


.loop ul li {
    width: calc(100vw / 4);
}
section.index2::before {
    height: 132px;
    bottom: -10px;
}
section.index2 > div > p:first-child {
    width: calc(50% - 192px);
}
section.index2 > div > p:nth-child(2) {
    width: calc(44% - 192px);
}
section.index2 > div div {
    width: 384px;
}
section.index2 > div div p {
    font-size: 23px;
}


/*------------------------------------*\
    アーカイブ1000
\*------------------------------------*/





/*------------------------------------*\
    下層ページ1000
\*------------------------------------*/

.ttl-page {
    font-size: 18px;
}
.ttl-page span {
    font-size: 35px;
    letter-spacing: 18px;
    margin-bottom: 20px;
}


section.contact-f table th {
    padding: 15px 0;
    width: 180px;
}
section.contact-f table td {
    padding: 15px 0 15px 15px;
}
section.contact-f table td span {
    font-size: 15px;
}
section.contact-f p input.wpcf7-form-control.wpcf7-submit {
    margin-top: 30px;
    font-size: 17px;
    -webkit-transition: unset;
    -o-transition: unset;
    transition: unset;
}






}





@media screen and (max-width: 700px) {

.width {
	width:96%;
}
p {
	font-size:15px;
	letter-spacing:0.5px;
	margin-bottom:5px;
}
.sentence p {
	line-height: 26px;
}
.floatr p.float, .floatl p.float,.floatr p.float.fi_small, .floatl p.float.fi_small {
	float:unset;
	width:100%;
	margin:0 auto 10px;
}


/*------------------------------------*\
    ヘッダー＆フッダー700
\*------------------------------------*/



footer#colophon {
    font-size: 12px;
}
footer#colophon br {
    display: block;
}



/*------------------------------------*\
    トップページ700
\*------------------------------------*/


.ttl1, .ttl5, .ttl8, .dannetsu > span {
    font-size: 16px;
}
.ttl1 span {
    font-size: 30px;
    letter-spacing: 15px;
    margin-bottom: 15px;
    font-weight: normal;
    padding-left: 12px;
}
.ttl2, .ttl4 {
    font-size: 16px;
    padding-bottom: 10px;
}
.ttl2 span, .ttl4 span:first-child {
	font-size:30px;
	letter-spacing: 8px;
}
.ttl3 {
    font-size: 18px;
    padding: 8px;
    margin-bottom: 10px;
}
.ttl4 span:first-child {
    margin-bottom: 5px;
}
.ttl6 {
    text-align: left;
}
.ttl6 i {
    display: inline-block;
    width: 23px;
    font-size: 20px;
    margin-right: 20px;
    vertical-align: middle;
}
.ttl6 span {
    display: inline-block;
    width: calc(100% - 45px);
    font-size: 23px;
    vertical-align: middle;
}
.ttl7 {
    padding: 10px 10px 10px 5px;
}
.ttl7 > span:first-child {
    font-size: 20px;
    margin-right: 30px;
}
.ttl7 > span:first-child::before {
    width: 100px;
    height: 100px;
}
.ttl9 {
	font-size:18px;
	margin-bottom:10px;
}
.ttl10 {
    font-size: 25px;
    letter-spacing: 1px;
}

p.icon1 {
    font-size: 50px;
}

p.link1 a, p.link1a a {
    min-width: 220px;
    padding: 15px 10px;
    margin: 5% auto;
}
ul.link2 li a {
    padding: 10px 0 13px;
    min-width: 140px;
}
ul.link2 li a img {
    width: 20px;
}
ul.link2 li a span {
    font-size: 14px;
}
ul.link3 li a {
    padding: 15px 15px 15px 5px;
}
ul.link3 li,ul.link3 li:last-child {
    min-width: 140px;
    margin: 0 1% 2%;
    width: 45%;
}
ul.link3 li a i {
    right: 7px;
    font-size: 16px;
}
ul.link3 li a:hover i {
    right:7px;
}

section.main div p:first-child {
    font-size: 25px;
    margin-bottom: 15px;
    letter-spacing: 5px;
}
section.main div h1 {
    font-size: 12px;
    letter-spacing: 1px;
}
section.main ul li:first-child {
    max-height: unset;
}
section.main ul li:nth-child(2) {
    display: none;
}
section.main ul li {
    width: 50%;
}

.index1a {
    width: 100%;
    margin: 10% auto 2%;
}
.index1a > p:first-child, .index1b > p:first-child {
    font-size: 70px;
    top: -50px;
}
.index1a p.by {
    width: calc(94% - 76px);
}
.index1a h2, .index1b h2, .index1c h2 {
    font-size: 25px;
}
.index1a div,.index1b div {
    width: 94%;
    margin: 5% auto 0;
}
.index1b {
    width: 100%;
    margin-right: 0;
}
.index1b > p.by {
    width: 100%;
    height: 150px;
}
.index1b h2 {
    -webkit-writing-mode: unset;
        -ms-writing-mode: unset;
            writing-mode: unset;
    margin: 3% 3% -3%;
}
.index1c > p:first-child {
    font-size: 70px;
    width: 97%;
    margin-left: 3%;
}
.index1c > p.by {
    position: absolute;
    width: calc(94% - 76px);
    top: 0;
    right: 0;
    height: 300px;
}
.index1c h2 {
    position: unset;
    margin: 3%;
}


section.back_yellow div.width p.link1 {
    margin: 0 auto;
}

.loop {
    padding: 5px 0;
}
.loop ul li {
    width: calc(100vw / 3);
    border-right: 10px solid #ddd0;
}

section.index2 {
    margin-top: 0;
}
section.index2::before {
    height: 40%;
}
section.index2 > div > p:first-child {
    width: 50%;
    max-width: 260px;
}
section.index2 > div > p:nth-child(2) {
    width: 40%;
    max-width: 200px;
}
section.index2 > div div {
    width: 100%;
}
section.index2 > div div p {
    font-size: 4.93vw;
    letter-spacing: 3px;
}
.index3 div.width p:first-child {
    font-size: 12px;
}



/*------------------------------------*\
    アーカイブ700
\*------------------------------------*/





/*------------------------------------*\
    下層ページ700
\*------------------------------------*/

.ttl-page {
    font-size: 16px;
}
.ttl-page span {
	font-size: 30px;
	letter-spacing: 15px;
	margin-bottom: 15px;
}
section.bread li {
    font-size: 12px;
}
section.bread li a {
    padding: 13px 0;
}

section.contact-f table {
    border-collapse: collapse;
    border-spacing: 0;
}
section.contact-f table th {
    display: block;
    width: 100%;
    padding: 10px 0;
}
section.contact-f table td {
    padding: 10px 0;
    width: 100%;
    display: block;
}
section.contact-f table td span.wpcf7-list-item span {
    letter-spacing: 0.5px;
}
section.contact-f table td input.wpcf7-text {
    width: 100%;
}
section.contact-f p input.wpcf7-form-control.wpcf7-submit {
    min-width:150px;
}

ul.sitemap > li {
    width: 100%;
    margin: 0 auto;
}

table.co-info {
    border-collapse: collapse;
    border-spacing: 0;
}
table.co-info tr {
    box-shadow: unset;
}
table.co-info th {
    width: 100%;
    display: block;
    padding: 8px;
    text-align: left;
}
table.co-info td {
    width: 100%;
    display: block;
    padding: 8px;
}	

ul.listc li {
    line-height: 26px;
    font-size: 15px;
}

ul.flow > li::before {
    top: auto;
    bottom: -3%;
}







}

/*----------------
 * 下層ページ追加css 2024.10.10
 * --------------*/
.page-service_content {
	display:inline-block;
	margin-bottom:20px;
}

.page-service_content-2 {
	display:block;
	margin-bottom:20px;
}

.page-service .float-r {
	float:right;
	margin-left:20px;
}

.page-service .float-r img {
	width:250px;
	height:180px;
	object-fit:contain;
}

.service-h3 {
	font-size: 26px;
    border-bottom: 1px solid #707070;
    padding: 10px;
    margin-bottom: 20px;
	text-align:center;
}

.service-h3>.tub,
.service-h3>.sp {
	display:none;
}

.service-h3.img {
	border:none;
}

.service-h3.img img {
	width: 250px;
	object-fit:cover;
	margin:20px auto;
}

.check_list>li {
    display: flex;
    align-items: start;
    margin-bottom: 20px;
}

.check_list>li>img {
    width: 30px;
    height: 30px;
    object-fit: contain;
    margin-right: 10px;
}

.main_txt span {
	font-weight:bold;
	color:#dbbd73;
}

.polyurea-product ul {
	display: flex;
    margin-bottom: 20px;
    justify-content: space-between;
}
.polyurea-product ul li {
	width: 33%;
}

.polyurea-works ul {
	display:flex;
	justify-content:space-between;
}

.polyurea-works ul li {
	width: 15%;
}

.polyurea-works img {
    width: 100%;
    object-fit: cover;
    height: 150px;
}

.reform-works ul {
	display:flex;
	justify-content:space-between;
}

.reform-works ul li {
	width: 24%;
}

.reform-works img {
    width: 100%;
    object-fit: cover;
    height: 200px;
}

.rhino-link {
    width: fit-content;
    margin: 20px auto;
}

.rhino-link>a {
	display:flex;
    align-items: center;
}

@media screen and (max-width:1023px) {
    .check_list>li>img {
        width: 20px;
        height: 20px;
    }
    .polyurea-product ul  {
        flex-direction: column;
    }
    .polyurea-product ul li {
        width: 50%;
        margin: 0 auto;
    }
    .polyurea-works ul {
        flex-wrap: wrap;
    }
    .polyurea-works ul li {
        width: 30%;
        margin-bottom: 30px;
    }
	.service-h3>.tub {
	display:block;
}
}
@media screen and (max-width:600px) {
    .service-h3 {
        font-size: 22px;
    }
    .page-service .float-r {
        float: unset;
        margin:0 0 20px 0;
    }
    .polyurea-product ul li {
        width: 90%;
    }
    .polyurea-works ul li {
        width: 48%;
        margin-bottom: 15px;
    }
    .page-service .float-r img {
        margin: 0 auto;
    }
	.reform-works ul {
		flex-wrap:wrap;
	}
	.polyurea-works ul li {
        width: 48%;
        margin-bottom: 15px;
    }
	.reform-works img {
		width: 100%;
    object-fit: cover;
    height: 200px;
    object-position: left;
	}
	
.service-h3>.sp {
	display:block;
}
}

/*------
 * 2024.12.10追記
 * --------*/
.com-btn>a {
	width: 200px;
	margin: 20px auto;
    background: #dbbd73;
    padding: 10px 0;
    text-align: center;
	text-decoration:none;
	color:#fff;
	display:block;
}

.com-btn>a:hover {
	background:#707070;
}

.page-contents_content {
	margin-bottom:20px;
}

.page-contents_content-2 {
	display:block;
	margin-bottom:20px;
}

.page-contents .float-r {
	float:right;
	margin-left:20px;
}

.page-contents .float-r img {
	width: 400px;
    height: 250px;
    object-fit: contain;
}

.contents-ttl {
	font-size: 26px;
    border-bottom: 1px solid #707070;
    padding: 10px;
    margin: 20px 0 30px;
	text-align:center;
}
.contents-ttl>.num {
	color:#dbbd73;
	font-weight:bold;
}

.contents-ttl>.tub,
.contents-ttl>.sp {
	display:none;
}

.contents-ttl.img {
	border:none;
}

.contents-ttl.img img {
	width: 250px;
	object-fit:cover;
	margin:20px auto;
}
.content-ttl-h2 {
	text-align:left;
}
.content-ttl-h3 {
	color: #dbbd73;
	font-weight:bold;
	font-size:20px;
	margin: 15px 0 20px;
}

@media screen and (max-width:1024px) {
    .page-contents .float-r img {
        width: 300px;
    height: 200px;
    }	
}

@media screen and (max-width:600px) {
    .contents-ttl {
        font-size: 22px;
    }
	.content-ttl-h3 {
		font-size:18px;
	}
    .page-contents .float-r {
        float: unset;
        margin:0 0 20px 0;
    }
    .page-contents .float-r img {
        margin: 0 auto;
    }	
.contents-ttl>.sp {
	display:block;
}
}

/*--------------------
 * 25.09.01 DC追記
 * --------------------*/
.top_content {
	display:flex;
	flex-wrap:wrap;
	justify-content:space-between;
}
.top_content_area {
	width:49%;
	margin-bottom:2%;
}
.top_content_area .contents-ttl {
	font-size:22px;
	white-space: nowrap; /* 折り返し無しにする */
    overflow: hidden; /* はみ出た部分を非表示 */
    text-overflow: ellipsis; /* 語尾を3点リーダーに */
}
.top_content_area .float-r {
	width:35%;
}
.top_content_area .float-r img {
	width:100%;
	object-fit:contain;
	height:auto;
}
.top_content_area .main_txt {
	display: -webkit-box; /* 必須 */
    -webkit-box-orient: vertical; /* 必須 */
    -webkit-line-clamp: 3; /* 行数を制限 */
    overflow: hidden; /* はみ出た部分を非表示 */
}
@media screen and (max-width:1000px) {
	.top_content_area {
		width:100%;
		margin-bottom:2%;
	}
	.top_content .top_content_area:nth-of-type(3),
	.top_content .top_content_area:nth-of-type(4) {
		display:none;
	}
	.top_content_area .float-r {
		float:unset;
		width:80%;
		margin:0 auto 2%;
	}
}
/*-------------------
25.11.06 DC追記
----------------------*/
.dc_column {
    margin: 3% auto;
}
.dc_ttl1 {
    color: #dbbd73;
    font-weight: bold;
    letter-spacing: 1px;
    margin-bottom: 2%;
    font-size: 24px;
}
.dc_list1 {
    max-height: 200px;
    overflow-y: scroll;
    margin: 3% 0;
}
.dc_list1 li {
    border-bottom: #dbbd73 dashed 1px;
    margin-bottom: 10px;
    padding-bottom: 10px;
}
.dc_list1 a {
    text-decoration: none;
    color: #000;
    transition: all .3s;
}
.dc_list1 a:hover {
    opacity: .8;
}
.dc_ttl2 {
    padding: 0;
    margin: 5px 0;
    border: none;
    white-space: nowrap; /* 折り返し無しにする */
    overflow: hidden; /* はみ出た部分を非表示 */
    text-overflow: ellipsis; /* 語尾を3点リーダーに */
    color: #dbbd73;
    font-size: 18px;
}
.dc_read_txt {
    display: -webkit-box; /* 必須 */
    -webkit-box-orient: vertical; /* 必須 */
    -webkit-line-clamp: 2; /* 行数を制限 */
    overflow: hidden; /* はみ出た部分を非表示 */
    line-height: normal;
    margin: 0 !important;
}
.dc_column_link {
    text-align: right !important;
}
.dc_column_link a {
    text-decoration: none;
    color: #000;
    transition: all .3s;
}
.dc_column_link a:hover {
    color: #dbbd73;
    opacity: .8;
}