@charset "utf-8";

/* -----------------------------
	共通
-------------------------------- */
.ttl-block{
	position: relative;
}

.ttl-block::before{
	content: '';
	position: absolute;
	width: 212px;
	height: 215px;
	background: url("../img/red-circle.svg") no-repeat top center / contain;
	top: -30px;
    left: -30px;
}

.ttl-block .jp{
	font-family: var(--fude);
	font-size: 8rem;
	-ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-orientation: upright;
	position: relative;
	white-space: nowrap;
}
.ttl-block .jp span{
	position: relative;
	right: -20px;
}

@media screen and (max-width: 768px){
	.ttl-block .jp{
		font-size: 4rem;
		-ms-writing-mode: initial;
		writing-mode: initial;
		text-orientation: initial;
	}
	.ttl-block::before{
		width: 80px;
		height: 80px;
		top: 0;
		left: 0;
		transform: translateX(0);
		-webkit-transform: translateX(0);
		-ms-transform: translateX(0);
	}
	.ttl-block .jp span{
		right: 0;
		top: 10px;
	}
}


/* -----------------------------
	.intro
-------------------------------- */
.greeting-philosophy-bg{
	/*background: url("../img/company-bg01.jpg") no-repeat bottom center / cover;*/
	padding: 100px 0 30vw;
    position: relative;
}

.greeting-philosophy-bg::before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 30vw;
    background: url("../img/commitment-bg.png") no-repeat top center / cover;
}


.greeting-area{
	/*color: #fff;*/
}
.greeting-area .inner{
	display: flex;
}
.greeting-area .ttl-block{
	margin: 0 0 0 30px;
}
.greeting-area .txt-box{
	margin: 0 100px 0 160px;
	position: relative;
}
.greeting-area .catch{
	font-size: 4rem;
}
.greeting-area .name{
	font-size: 2.4rem;
	font-family: var(--mincho);
	font-weight: bold;
	margin: 40px 0 0;
	text-align: right;
}

@media screen and (max-width: 768px){
	.greeting-philosophy-bg{
		padding: 30px 0 50vw;
	}
    .greeting-philosophy-bg::before {
        height: 50vw;
        background: url("../img/commitment-bg.png") no-repeat top center / cover;
    }
	.greeting-area{
	}
	.greeting-area .inner{
		display: block;
	}
	.greeting-area .ttl-block{
		margin: 0;
	}
	.greeting-area .txt-box{
		margin: 20px 0 0;
	}
	.greeting-area .catch{
		font-size: 2.4rem;
		margin: 0 0 10px;
	}
	.greeting-area .name{
		font-size: 1.6rem;
		margin: 20px 0 0;
	}
}

/* -----------------------------
	philosophy-area
-------------------------------- */
.philosophy-area{
	/*color: #fff;*/
	/*padding: 95px 0 0;*/
}
.philosophy-area .inner{
	/*display: flex;
    align-items: center;*/
	/*flex-direction: row-reverse;*/
}
.philosophy-area .ttl-block{
	margin: 30px 140px 0 0;
}
.philosophy-area .txt-box{
	/*margin: 0 100px 0 0;*/
    text-align: center;
}
.philosophy-area .sec-ttl {
    font-size: 2.4rem;
    font-family: var(--mincho);
    margin: 0 0 20px;
}
.philosophy-area .catch{
	font-size: 4rem;
}
@media screen and (max-width: 768px){
	.philosophy-area{
	}
	.philosophy-area .inner{
		display: block;
	}
	.philosophy-area .ttl-block{
		margin: 0;
	}
	.philosophy-area .txt-box{
		margin: 20px 0 0;
	}
    .philosophy-area .sec-ttl {
        font-size: 2.0rem;
        margin: 0 0 15px;
    }
	.philosophy-area .catch{
		font-size: 2.6rem;
		margin: 0 0 10px;
	}
    .philosophy-area .basic-txt {
        text-align: left;
    }
}

/* -----------------------------
	summary-area
-------------------------------- */
.summary-area{
	padding: 100px 0;
    background: var(--black);
}
/* テーブル */
.summary-area table{
	width: 100%;
	border-collapse: collapse;
	line-height: 1.6;
	font-family: var(--mincho);
	font-weight: 600;
    color: #fff;
}

.summary-area table tr:not(:last-child){
	border-bottom:1px solid #ddd;
}

.summary-area table th{
	text-align: left;
	vertical-align: top;
	
	padding: 25px 0 25px 30px;
	width: 180px;
}

.summary-area table td{
	padding: 25px;
}

.summary-area .access-btn {
    display: inline-block;
    padding: 5px 15px;
    border: 1px solid #fff;
    color: #fff;
    border-radius: 20px;
    margin: 10px 0 0;
    font-size: 1.4rem;
}

.summary-area .access-btn i {
    margin-right: 3px;
}

.summary-area table .disc-list {
    margin: 0;
}

.summary-area table .tel {
    font-size: 2.4rem;
    display: inline-block;
    color: #fff;
}

.summary-area table .tel i {
    font-size: 1.8rem;
    margin-right: 5px;
}

@media (hover: hover) and (pointer: fine) {
    .summary-area .access-btn:hover {
        background: #fff;
        color: #333;
    }
}


@media screen and (max-width: 768px){
	.summary-area{
		padding: 30px 0;
	}
	
	.summary-area table th{
		padding: 20px 0 10px 0;
		display: block;
		width: auto;
	}
	
	.summary-area table td{
		padding: 0 0 20px;
		display: block;
	}
}


/* -----------------------------
	access-area
-------------------------------- */
.access-history-bg{
	background: url("../img/company-bg02.jpg") no-repeat bottom center / cover;
	padding: 85px 0 660px;
}
.access-area{
	color: #fff;
	padding: 0 0 0;
}
.access-area .inner{
	display: flex;
	justify-content: space-between;
}
.access-area .ttl-block{
	margin: 45px 0 0;
}
.access-area .ttl-block .jp{
	line-height: 1;
	margin: 0 auto;
}
.access-area .ttl-block .jp span{
	right: -10px;
}
.access-area .basic-txt{
	font-family: var(--mincho);
	font-size: 1.8rem;
	line-height: 1.9;
	margin: 30px 0 0;
}

.access-area iframe{
	width: 70%;
	height: 500px;
	margin: 70px 0 0;
    filter: saturate(0.5);
    transition: all .3s;
}

.access-area iframe:hover {
    filter: none;
}

@media screen and (max-width: 768px){
	.access-history-bg{
		background: url("../img/company-bg02-sp.jpg") no-repeat bottom center / cover;
		padding: 20px 0 200px;
	}
	.access-area{
	}
	.access-area .inner{
		display: block;
	}
	.access-area .ttl-block{
	}
	.access-area .ttl-block::before{
		top: -20px;
	}
	.access-area .ttl-block .jp{
	}
	.access-area .ttl-block .jp span{
		right: 0;
	}
	.access-area iframe{
		width: 100%;
		height: 50vw;
		margin: 20px 0 0;
	}
}

/* -----------------------------
	history-area
-------------------------------- */
.history-area{
	color: #fff;
	margin: 130px 0 0;
}
.history-area .inner{
	display: flex;
	justify-content: space-between;
}
.timeline{
	margin: 0 0 0 170px;
}
.timeline > li {
	margin: 0;
	position: relative;
}
.time-date {
	font-family: var(--mincho);
	font-size: 2.1rem;
	font-weight: bold;
    line-height: 1.6;
}
.timeline-content {
	width: 80%;
	/*float: left;*/
	/*border-left: 1px #656565 solid;*/
	padding-left: 37px;
	font-family: var(--mincho);
}

.timeline > li:not(:last-child)::before {
    content: "";
    display: inline-block;
    position: absolute;
    top: 10px;
    left: 0;
    width: 1px;
    height: 100%;
    background: #656565;
    
}

.timeline > li:not(:last-child) {
    padding-bottom: 20px;
}

.timeline > li:nth-child(2) .timeline-content{
	/*padding: 30px 0 0 37px;*/
}
.timeline > li:nth-child(3) .timeline-content{
	/*padding: 30px 0 30px 37px;*/
}
.timeline > li:nth-child(4) .timeline-content{
	border-left: none;
}
.timeline-content:before {
	content: '';
	width: 17px;
	height: 17px;
	background: var(--red);
	position: absolute;
	left: -8px;
	border-radius: 100%;
}

.timeline > li .timeline-content:before {
    top: 10px;
}

.timeline-content .basic-txt{
	margin: 20px 0 0;
}

@media screen and (max-width: 768px){
	.history-area{
		margin: 50px 0 0;
	}
	.history-area .inner{
		display: block;
	}
	.timeline{
		display:table;
		margin: 0 0 0 20px;
	}
	.timeline > li {
	}
	.time-date {
		line-height: 1.6;
	}
	.timeline-content {
		width: 100%;
        position: relative;
	}
	.timeline > li:nth-child(2) .timeline-content{
	}
	.timeline > li:nth-child(3) .timeline-content{
	}
	.timeline > li:nth-child(4) .timeline-content{
	}
	.timeline-content:before {
	}
	.timeline-content .basic-txt{
		margin: 10px 0 0;
	}
}