@charset "UTF-8";

* {
    margin: 0px;
    padding: 0px;
    box-sizing: border-box;
    font-family: 'Roboto', sans-serif;
}

body {
    background: #ffffff;
    margin: 0 auto;
    max-width: 90%;
}

/* ヘッダー */

header {
    padding-top: 40px;
}

img {
	width: 100%;
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}

.logo {
    padding: 0 10px;
    margin-left: auto;
    margin-right: auto;
    display: block;
    width: 230px;
}

ul {
    list-style-type: none;
}

.nav ul li a {
    text-decoration: none;
    color: #3b3b3b;
    display: block;
    text-transform: uppercase;
    text-align: center;
    padding: 20px;
    font-size: 15px;
}

/* メイン */

a {
    text-decoration: none;
    color: #3b3b3b;
}

a:hover {
    color: #5dbbff;
}

h1 {
    font-size: 35px;
    letter-spacing: 2px;
}

h2 {
    font-size: 25px;
    letter-spacing: 2px;
    color: #3b3b3b;
}

h3 {
    font-size: 16px;
}

h4 {
    font-size: 15px;
    color: #3b3b3b;
}

.caption {
    overflow: hidden;
    position: relative;
}

.caption .caption-text {
	font-size:		130%;
    font-weight: 500;
	text-align: 		center;
	padding-top:		90%;
	color:			#3b3b3b;
}

.caption .mask {
	width:			100%;
	height:			100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(255,255,255,0.8);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}

.caption:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

/*コンセプト画像*/
.concept-img {
    background-image: url("../img/concept-mobile.jpg");
    background-size: cover;
    padding: 60px 40px 150px;
    color: #ffffff;
    text-align: center;
    letter-spacing: 2px;
}

.concept-img h3 {
    padding-top: 40px;
    letter-spacing: -1px;
}

footer {
    text-align: center;
    padding: 20px 0px;
    background-color: #f7f7f7;
    font-size: 10px;
}

footer p {
    padding-top: 10px;
}

.col {
	width: 50%;
    float: left;
    padding: 0px 5px;
    opacity: 0;
}

.pickup-slide .col{
    opacity: 10;
}

.row {
    overflow: hidden;
}

.row a .col{
    transition: .8s;
}

.col-fade{
	opacity: 1.0;
}

.col h4 {
    padding: 10px 5px 30px ;
}

.No {
    float: left;
}

.date {
    float: right;
}
/* -----------ページネーション------------ */
.pager {
    overflow: hidden;
    padding: 5px 0 20px;
    z-index: 100;
}

.pager ul {
    position: relative;
    bottom: 4px;
    left: 50%;
    float: left;
}

.pager ul li {
    position: relative;
    left: -50%;
    float: left;
    padding: 0 20px;
}

.pager ul li a {
    display: block;
    font-size: 20px;
    padding: 5px 10px ;
    border-radius: 10px;
}

.page1 {
    background: #3b3b3b;
    color: #fff;
}

.page2 {
    border: 2px solid #3b3b3b;
}

.page3 {
    border: 2px solid #3b3b3b;
}

.page4 {
    background: #3b3b3b;
    color: #fff;
}

/* -------------ここまで--------------*/
.snapshot {
    text-align: center;
    padding-top: 50px;
    padding-bottom: 50px;
    letter-spacing: 2px;
}

.pickup {
    background-color: #fff2e3;
}

.pickup-slide {
    z-index: 10;
}

.line {
    display: flex;
    align-items: center;
    padding-top: 30px;
    padding-bottom: 30px;
}
.line:before, .line:after {
    content: "";
    flex-grow: 1;
    height: 1px; /* 線の太さを変えたいときはここを変える */
    background: #000; /* 線の色を変えたいときはここを変える */
    margin:0.5em; /* 文字と線の余白用 なくても良い */
}
/* ---------------コンセプト---------------*/
.concept {
    text-align: center;
}

.concept-contents {
    padding: 1em 0;
}

.concept h4 {
    padding: 20px 0px 0;
}

.concept p {
    font-size: 15px;
    padding: 0px 10px 0px;
    line-height: 26px
}
/* ---------------コンタクト----------------*/
.contact {
    text-align: center;
    padding-bottom: 30px;
}

.contact p {
    padding: 1em 0;
}

.personal {
    padding: 30px 1em;
}

.name h3 {
    padding-top: 1em;
    line-height: 30px;
}

.icon {
    border-radius: 30%;
    width: 30%;
    float: right;
}

/* コンタクトページ */
.contact-prof {
    line-height: 40px;
    text-align: center;
    padding: 3em 0;
}

/* メイン画像 */
.hero1 {
    background-image: url("../img/hero_mobile.jpg");
    background-size: cover;
    padding: 200px 40px 60px;
    color: #ffffff;
    text-align: center;
    letter-spacing: 2px;
}

.hero2 {
    background-image: url("../img/snap-97.jpg");
    background-size: cover;
    padding: 200px 40px 60px;
    color: #ffffff;
    text-align: center;
    letter-spacing: 2px;
}

.hero3 {
    background-image: url("../img/snap-100.jpg");
    background-size: cover;
    padding: 200px 40px 60px;
    color: #3b3b3b;
    text-align: center;
    letter-spacing: 2px;
}

.hero-text {
    padding-top: 30px;
    letter-spacing: -1px;
}

.none {
    display: none;
}

.row:before, .row:after {
	content: "";
	display: table;
}

.row:after {
	clear: both;
}

/*-----------------Tablet View-----------------*/

@media (min-width: 768px){
    h1 {
        font-size: 50px;
    }
    
    h2 {
        font-size: 30px;
    }
    
    h3 {
        font-size: 25px;
        letter-spacing: 3px;
    }
    
    h4 {
        font-size: 20px;
        letter-spacing: 1px;
    }
    
    .hero1 {
        background-image: url("../img/hero.jpg");
        padding: 220px 40px 40px ;
        text-align: left;
    }
    
    .hero2 {
        background-image: url(../img/hero2.jpg);
        padding: 220px 40px 40px ;
        text-align: left;
    }
    
    .hero3 {
        background-image: url(../img/hero3.jpg);
        padding: 220px 40px 40px ;
        text-align: left;
    }
    
    .concept-img {
        background-image: url(../img/concept.jpg);
        padding: 60px 90px 150px;
    }
    
    .personal {
        padding: 50px 2em;
    }
    
    .col {
        padding: 0px 10px;
    }
    
    .col h4 {
    padding: 10px 5px 40px ;
    }
    
    .concept p {
        padding: 0px 80px 0px;
    }
}

/* デスクトッぷ */

@media (min-width: 1024px){
    header {
        padding: 50px 0 20px;
    }
    
    body {
        max-width: 1280px;
        margin: 0 auto;
    }
    
    .logo {
        width: 280px;
    }
    
    h1 {
        font-size: 70px;
    }
    
    h3 {
        font-size: 30px;
    }
    
    .hero1 {
        height: auto;
        padding: 450px 60px 100px ;
    }
    
    .hero2 {
        height: auto;
        padding: 450px 60px 100px ;
    }
    
    .hero3 {
        height: auto;
        padding: 450px 60px 100px ;
    }
    
    .concept-img {
        padding: 60px 10em 15em;
    }
    
    .col {
        padding: 0px 15px;
    }
    
    .col h4 {
        padding: 15px 8px 45px;
    }
    
    .col-lg-one-fourth {
		width: 33.3%;
	}
    
    .concept p {
        padding: 0px 200px 0px;
    }
    
    .name h3 {
        padding-top: 2em;
        line-height: 40px;
    }
    
    .contact-prof {
        line-height: 50px;
    }
}