/*--------------------------------------------------------------
	studycase
--------------------------------------------------------------*/

.navbar-custom + .main {
    margin-top: 147px;
}

.container .font-alt {
    font-family: "Hiragino Kaku Gothic ProN", Meiryo, "メイリオ", sans-serif;
    text-transform: inherit;
    letter-spacing: 0;
	line-height: 1.8;
}

section#title00 {
	background: #40AF36;
	text-align: center;
	padding: 50px;
	color: #FFF;
	font-size: 2.8rem;
}

.studylist .c12c {
	font-size: 1.6rem;
	text-align: center;
}

.list {
	padding-top: 50px;
}

.list .inner {
	border: 1px solid #999;
	position: relative;
	padding-bottom: 10px;
}

.list .img {
	margin: 0;
	position: relative;
}

.list .img p {
	position: absolute;
	background: rgba(255,255,255,0.6);
	z-index: 10;
	margin: 0;
	padding: 5px;
	width: 100%;
	text-align: right;
	bottom: 0;
	left: 0;
}

.list p.text {
	padding: 10px;
	margin-bottom: 0;
	font-size: 1.4rem;
}

.list .logo {
	text-align: center;
}

section.title01 .container {
	background: url("../../casestudy/images/photo45.jpg");
    background-repeat: no-repeat;
    background-position: top 50% left 0;
    background-size: cover;
    padding-top: 20px;
    padding-bottom: 500px;
	 min-height: 535px;
}

section.title01 .container h2 {
	font-size: 2.2rem;
	text-align: left;
	position: relative;
	padding-top: 20px;
	margin: 0 0 10px;
	font-weight: bold;
}

section.title01 .container p {
	font-size: 1.6rem;
	position: relative;
}

.module.title01, .module.casest01 {
    padding: 0;
}

.container h3 {
	font-weight: bold;
}

.casest01 p {
	color: #4A90E2;
	font-size: 20px;
	line-height: 1.8;
	font-weight: bold;
}

.casest01 p span {
	font-size: 14px;
	line-height: 1.6;
}

.c12c {
	text-align: center;
}

p.c12c28 {
	font-size: 2.8rem;
	text-align: center;
}

p.c12c20 {
	font-size: 2.0rem;
	text-align: center;
}

p.c12c16 {
	font-size: 1.6rem;
	text-align: center;
}

.img {
	margin-top: 10px;
	margin-bottom: 10px;
}

.pcR {	float: right;}
.pcL {	float: left;}

.casest01 h3 {
	color: #333;
	font-size: 2.4rem;
	line-height: 1.6;
	margin-top: 0;
	margin-bottom: 20px;
}

p.que {
	color: #4A90E2;
	font-size: 1.8rem;
	line-height: 1.8;
	font-weight: bold;
}
p.que.c12c {
	color: #4DA7CB;
	font-weight: normal;
}

p.ans {
	color: #333;
	font-size: 1.6rem;
	line-height: 1.8;
	margin-bottom: 30px;
	font-weight: normal;
}

p.ans .point {
	color: #4A90E2;
	font-size: 1.6rem;
	font-weight: bold;
}

p.imgtxt {
	color: #4A90E2;
	font-size: 1.6rem;
	font-weight: bold;
}

.casest01 h5 {
	font-size: 16px;
	margin-bottom: 5px;
}

.casest01 ul {
	margin-bottom: 5px;
}

.casest01 ul li a {
	color: #006934;
	font-size: 14px;
}


.wrapper.tile .row div a {
	padding:1px;
	display:block;
	border:0;
}

.wrapper.tile .row div img {
	width:100%;
	display:block;
}

.wrapper.tile .row div a:hover img {
	opacity:0.6;
	filter:alpha(opacity=60);
	-ms-filter: "alpha( opacity=60 )";
}

.wrapper.tile .row .block {
	position:relative;
}

.works-grid-4 .work-item {
	border: 1px solid #FFF;
	margin-bottom: 0;
}

#contactBtn a {
	font-size: 1.6rem;
}

p a.btn {
	font-size: 1.6rem;
	font-weight: bold;
}

p a.btn {
	max-width: 385px;
	width: 100%;
}

.portfolio-page-header .container {
	height: 500px;
}

#contentslineup .row > div.col-xs-6 {
	height: 630px
}

input.inputButton01[type="submit"] {
	border-radius: 50px;
}

.inputButton02 a {
	border-radius: 50px;
}

article#main header.special {
    padding: 100px 0 50px;
}

@media screen and (min-width: 1200px) {
	#contentslineup {
		position: relative;
	}
	#contentslineup .container {
		width: 1400px;
		position: relative;
		margin-left: -700px;
		left: 50%;
	}
}

@media screen and (min-width: 1414px) {
	#contentslineup .container {
		width: 1400px;
	}
}

#main .row > .\33 u {
    padding: 60px 0 50px 50px;
}

@media screen and (max-width: 1680px) {
	#main .row > .\33 u {
		padding: 60px 0 0 30px;
	}
}

@media screen and (max-width: 1280px) {
	#main .row > .\33 u {
		padding: 60px 0 0 30px;
	}
	.module-title {
		position: relative;
		letter-spacing: 4px;
		text-align: center;
		font-weight: 400;
		font-size: 20px;
		color: #111;
		margin: 0 0 70px;
	}
}

section h3 {
    color: #000;
}

#main .row  {
	margin: 0;
}



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

	section.title01 .container {
		background-position: center left 0;
		margin-top: 200px;
		padding-bottom: 200px;
		min-height: 0;
	}
	section.title01 .container p {
		font-size: 1.2rem;
		position: relative;
	}
	br.pc {
		display: none;
	}
	section.title01 .container h2 {
		font-size: 1.8rem;
	}
	.navbar-custom + .main {
		margin-top: 53px;
	}
	.casest01 p {
		font-size: 1.4rem;
	}
	p.ans .point {
		font-size: 1.4rem;
	}
	.c12c,
	p.c12c28,
	p.c12c20 {
		text-align: left;
	}
	.pcR {	float: none; clear: both;}
	.pcL {	float: none; clear: both;}
	.img {
		text-align: center;
		background: #EFEFEF;
		padding: 10px;
	}
	.list .img {
		text-align: center;
		background: #EFEFEF;
		padding: 0;
	}
	.btn {
    	white-space: normal;
	}
	.casest01 h3 {
		font-size: 2.0rem;
	}
	p.c12c28,
	p.c12c20 {
		font-size: 1.6rem;
		text-align: left;
	}
	a.next,
	a.prev {
		font-size: 1.6rem;
		padding: 8px 20px;
	}
}

#partner p {
    color: #000;
    font-size: 1.4rem;
}

@media screen and (max-width: 767px) {
	section.title01 .container {
		margin-top: 0;
		padding-top: 200px;
		padding-bottom: 0;
	}
}

@media screen and (max-width: 736px) {
	.container.\37 5\25 {
    	width: 90%;
	}
	.container.special h2 br {
	    display: block;
	}
}

/* =============================================
	追加CSS
================================================ */

.case05 {
	font-weight: bold;
}


/* case-menu
---------------------------------------------- */
.case-menu .case-menu-head {
	font-size: 1.8rem;
	padding: 10px 20px;
	color: #fff;
	text-align: center;
}

.case-menu .case-menu-body {
	padding: 10px 20px;
	text-align: left;
}

.case-menu .case-menu-body p {
	line-height: 1.6;
	margin-bottom: 0;
}

.case-menu .case-menu-body a {
	font-weight: normal;
	font-size: 1.6rem;
}

.case-menu .case-menu-body a:hover,
.case-menu .case-menu-body a:focus {
	text-decoration: underline;
}

@media screen and (max-width: 990px) {
	.case-menu .case-menu-head {
		font-size: 1.4rem;
		padding: 10px 10px;
	}
	
	.case-menu .case-menu-body {
		padding: 10px 10px;
	}

	.case-menu .case-menu-body a {
		font-size: 1.2rem;
	}
}

/*青*/
.case-menu.blue {
	background: #e8f3ff;
}

.case-menu.blue .case-menu-head {
	background: #036e9f;
}

.case-menu.blue .case-menu-body ul {
	color: #036e9f;
}

.case-menu.blue .case-menu-body a {
	color: #036e9f;
}

/*緑*/
.case-menu.green {
	background: #e5eee6;
}

.case-menu.green .case-menu-head {
	background: #006934;
}

.case-menu.green .case-menu-body ul {
	color: #006934;
}

.case-menu.green .case-menu-body a {
	color: #006934;
}


/* =============================================
	added 20250704
================================================ */

.case-head,
.case-main {
	font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Arial, "Helvetica Neue", Helvetica, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.8;
	color: #1a1918;
}

.case-head .bdrs8,
.case-main .bdrs8 {
	border-radius: 8px;
}

.fz14 {
	font-size: 14px;
}

.fz16 {
	font-size: 16px;
}

.case-head .tag,
.case-main .tag {
	font-size: 14px;
	font-weight: bold;
	display: inline-block;
	padding: 0px 8px 1px;
	color: #fff;
	background: #363433;
}


/* case-head
---------------------------------------------- */
.case-head {
	background: url("../../casestudy/images/case-head-bg.png") no-repeat center center / cover;
	position: relative;
}

.case-head .container {
	position: relative;
	z-index: 11;
}

.case-head .case-head-flex {
	display: flex;
}

.case-head .case-head-flex .img-wrap,
.case-head .case-head-flex .inner {
	flex: 1;
}

.case-head .case-head-flex .img-wrap {
	margin: 0;
}

.case-head .case-head-flex .inner-inner {
	padding-right: 20px;
	height: 100%;
}

.case-head .case-head-left {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	height: 100%;
}

.case-head .case-head-info {
	display: flex;
	align-items: center;
}

.case-head .case-head-info .tag {
	font-weight: 500;
	margin-right: 12px;
	color: #2e9963;
	background: rgba(46, 153, 99, 0.15);
}

.case-head .case-head-info .date {
	font-size: 14px;
	color: #808080;
}

.case-head h1 {
	font-size: 28px;
	line-height: 1.5;
	font-weight: bold;
}

.case-head p.case-head-sub {
	font-size: 20px;
	font-weight: 500;
}

.case-head .case-head-right-top {
	margin-bottom: 0;
}

@media (min-width: 1250px) {
	.case-head .container {
		width: 1230px;
	}
}

@media screen and (max-width: 768px) {
	.case-head {
		padding-top: 50px;
		padding-bottom: 50px;
	}

	.case-head .case-head-flex {
		flex-wrap: wrap;
		row-gap: 40px;
	}

	.case-head .case-head-flex .img-wrap,
	.case-head .case-head-flex .inner {
		flex: auto;
		width: 100%;
	}

	.case-head .case-head-flex .inner-inner {
		padding-right: 0;
	}

	.case-head h1 {
		font-size: 22px;
	}

	.case-head p.case-head-sub {
		font-size: 16px;
	}
}


/* case-main
---------------------------------------------- */
.case-pre-content {
	display: flex;
	padding: 32px 0;
	border-top: 4px solid #f6f6f6;
	border-bottom: 4px solid #f6f6f6;
}

.case-pre-content .img-wrap {
	flex-shrink: 0;
	margin: 0 40px 0 0;
}

.case-pre-content a {
	color: #0069cc;
	text-decoration: underline;
}

.case-pre-content a:hover {
	text-decoration: none;
}

.case-main .tit-h2 {
	font-size: 20px;
	font-weight: bold;
	padding: 16px 24px;
	margin-bottom: 20px;
	background: #f6f6f6;
}

.case-main .tit-p {
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 15px;
}

.case-main .caption {
	color: #808080;
	text-align: center;
}

.case-main .video-content {
	max-width: 830px;
	margin: 0 auto;
}

.case-main .video-content .videobox {
	width: 100%;
}

.case-main .flex {
	display: flex;
}

.case-main .aife {
	align-items: flex-end;
}

@media screen and (max-width: 990px) {
	.case-main .flex {
		display: block;
	}
}

@media screen and (max-width: 768px) {
	.case-pre-content {
		flex-wrap: wrap;
		row-gap: 20px;
	}

	.case-pre-content .img-wrap,
	.case-pre-content .inner {
		flex: auto;
		width: 100%;
		margin-right: 0;
	}
}


/* video-content-link
---------------------------------------------- */
.video-content-link {
	display: flex;
	align-items: center;
	border: 2px solid #ebebeb;
	color: #1a1918;
	transition: background .4s;
}

.video-content-link:hover {
	color: #1a1918;
	background: #ebebeb;
}

.video-content-link .img-wrap {
	flex-shrink: 0;
	margin: 0;
}

.video-content-link .img-wrap img {
	width: 264px;
	height: 200px;
	object-fit: cover;
}

.video-content-link .inner {
	flex-grow: 1;
	padding: 20px 40px;
}

.video-content-link .video-content-tit {
	font-size: 20px;
	font-weight: bold;
}

.video-content-link .arrow-link01 {
	display: inline-flex;
	align-items: center;
	color: #363433;
	text-decoration: none;
}

.video-content-link .arrow-link01 .icon {
	display: block;
	width: 24px;
	height: 24px;
	margin-left: 8px;
	border-radius: 50%;
	background: #b20000;
	transition: background 0.4s;
	position: relative;
}

.video-content-link .arrow-link01 .icon:after {
	content: "";
	position: absolute;
	top: 50%;
	right: calc(50% - 4px);
	width: 8px;
	height: 8px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	transform: rotate(45deg);
	transform-origin: right top;
}

@media screen and (max-width: 768px) {
	.video-content-link .img-wrap img {
		width: 200px;
	}

	.video-content-link .inner {
		padding: 15px 20px;
	}

	.video-content-link .video-content-tit {
		font-size: 18px;
		margin-bottom: 10px;
	}
}

@media screen and (max-width: 500px) {
	.video-content-link {
		flex-wrap: wrap;
	}

	.video-content-link .img-wrap,
	.video-content-link .inner {
		flex: auto;
		width: 100%;
	}

	.video-content-link .img-wrap img {
		width: 100%;
		height: auto;
	}
}


/* case-foot
---------------------------------------------- */
a.case-footer-btn {
	font-size: 16px;
	font-weight: bold;
	letter-spacing: 0.02em;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 296px;
	height: 56px;
	padding: 12px;
	border-radius: 56px;
	border: 1px solid #b20000;
	color: #1a1918;
	transition: all .4s;
	text-align: center;
}

a.case-footer-btn:hover {
	color: #fff;
	background: #b20000;
}

a.case-footer-btn .icon {
	flex-shrink: 0;
	width: 33px;
	height: 33px;
	border: 1px solid #fff;
	border-radius: 50%;
	background: #b20000;
	position: relative;
}

a.case-footer-btn .icon::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 8px;
	height: 8px;
	margin-left: -4px;
	border-top: 2px solid #fff;
	border-left: 2px solid #fff;
	transform: rotate(-45deg);
	transform-origin: left top;
}

a.case-footer-btn .text {
	flex-grow: 1;
	margin: 0;
}

.case-footer-links {
	display: flex;
}

.case-footer-links .link {
	display: flex;
	align-items: center;
	flex: 1;
	height: 208px;
	padding: 20px 48px;
	color: #fff;
	transition: opacity 0.4s ease-in-out;
}

.case-footer-links .link:first-of-type {
	background-image: linear-gradient(to right, rgba(46, 153, 99, 1) 0%, rgba(0, 128, 64, 1) 100%);
}

.case-footer-links .link:nth-of-type(2) {
	background-image: linear-gradient(to right, rgba(219, 47, 47, 1) 0%, rgba(178, 0, 0, 1) 100%);
}

.case-footer-links .link:hover {
	opacity: 0.7;
}

.case-footer-links .link .inner {
	flex-grow: 1;
}

.case-footer-links .link .link-main {
	font-size: 24px;
	font-weight: bold;
	margin-bottom: 10px;
}

.case-footer-links .link .icon {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	margin-left: 10px;
	border-radius: 50%;
	background: #fff;
	position: relative;
}

.case-footer-links .link .icon::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	right: 50%;
	width: 8px;
	height: 8px;
	margin-right: -4px;
	transform: rotate(45deg);
	transform-origin: right top;
}

.case-footer-links .link:first-of-type .icon::after {
	border-top: 2px solid #008040;
	border-right: 2px solid #008040;
}

.case-footer-links .link:nth-of-type(2) .icon::after {
	border-top: 2px solid #b20000;
	border-right: 2px solid #b20000;
}

@media screen and (max-width: 768px) {
	.case-footer-links .link {
		height: auto;
		padding: 40px 20px;
	}

	.case-footer-links .link .link-main {
		font-size: 20px;
	}
}

@media screen and (max-width: 500px) {
	.case-footer-links {
		flex-wrap: wrap;
	}

	.case-footer-links .link {
		flex: auto;
		width: 100%;
	}
}




