@charset "utf-8";

/* CSS RESET */

html, body, div, .padder, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, acronym, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

fieldset, img {
    border: 0;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, img, object, embed {
    display: block
}

address, caption, cite, code, dfn, th, var {
    font-style: normal;
    font-weight: normal;
}

nav ul, nav li {
    list-style: none;
}

caption, th {
    text-align: left;
}

h1, h2, h3, h4, h5, h6 {
    font-size: 100%;
    font-weight: normal;
    width: auto
}

q:before, q:after {
    content: "";
}

abbr, acronym {
    font-variant: normal;
}

sup {
    vertical-align: text-top;
}

sub {
    vertical-align: text-bottom;
}

input, textarea, select {
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
}

legend {
    color: #000;
}

a, .no-touch a:hover, .no-touch a:visited:hover, a:active, .no-touch a:active:hover {
    outline: none
}


/* a,.no-touch a:hover,.no-touch a:visited:hover,a:visited{text-decoration: none} */

a {
    outline: none;
}

::selection {
    background: #000;
    color: #fff;
    text-shadow: none;
}

::-moz-selection {
    background: #000;
    color: #fff;
    text-shadow: none;
}

::-webkit-selection {
    background: #000;
    color: #fff;
    text-shadow: none;
}

*, *:before, *:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

img {
    color: transparent;
    font-size: 0;
    border: none;
    outline: none;
    /* max-width: 100%; */
    /*
  For IE.
  http://css-tricks.com/ie-fix-bicubic-scaling-for-images
*/
    -ms-interpolation-mode: bicubic;
}

.maxw100 {
    max-width: 100%;
}

ul {
    list-style-type: none;
}


/* ------------------------------------------------------------------

____BASE

--------------------------------------------------------------------- */

* {
    -webkit-text-size-adjust: 100%;
}

html, body {
    width: 100%;
    margin: 0;
    padding: 0;
}

body {
    background: #fff;
    font-family: "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro W3", "Lucida Grande", "Hiragino Kaku Gothic Pro", "Verdana", "ＭＳ Ｐゴシック", sans-serif;
    font-size: 14px;
    line-height: 1.8em;
    color: #000000;
    -webkit-font-smoothing: antialiased;
    /* min-width: 960px; */
    min-width: 640px;
}

.container {
    margin: 0 auto;
    width: 100%;
    text-align: center;
}

.pc {
    display: block;
}

.sp {
    display: none;
}


/* __Fonts
---------------------------------- */

@font-face {
    font-family: 'Didot';
    src: url('../font/LivableDidot-Regular.eot?#iefix') format('embedded-opentype'), url('../font/LivableDidot-Regular.woff') format('woff'), url('../font/LivableDidot-Regular.otf') format('opentype');
    font-style: normal;
    font-weight: normal;
    overflow: hidden;
}

.font-arial {
    font-family: "Arial";
    font-weight: normal;
}

.font-arialBlack {
    font-family: "Arial Black";
    font-weight: normal;
}

.font-didot {
    font-family: "Didot";
    font-weight: normal;
}


/* __A
---------------------------------- */

a {
    text-decoration: none;
}

a:link, a:visited, a:active, a:hover {
    outline: none;
}

.center, .center img {
    text-align: center;
    margin: 0 auto;
}


/* ------------------------------------------------------------------

Header

--------------------------------------------------------------------- */

.header {
    width: 100%;
    height: 80px;
    background: #000;
    text-align: center;
    position: relative;
    z-index: 1000;
    margin: 0 auto;
}

h1.logo-inner a {
    width: 120px;
    display: block;
    margin: 0 auto;
    padding: 13px 0 10px 0;
}


/* Main visual
------------------------ */

.mainvisual {
    background: url(../img/img_main.jpg) no-repeat center center;
    background-size: cover;
    height: 670px;
	margin-bottom: 40px;
    padding: 60px 0;
}

.mainvisual img {
    margin: 0 auto;
}

.mainvisual p:first-child {
    margin-bottom: 45px;
}

/* Validate text
------------------------ */
.validate-text {
	margin-bottom: 58px;
}

.validate-text .inner {
	margin: 0 auto;
	width: 940px;
}

.validate-text .lead {
	font-weight: bold;
	font-size: 200%;
	letter-spacing: -0.04em;
	line-height: 1.4;
	text-align: center;
}

.validate-text .lead span {
	color: #27467f;
}

.validate-text p:first-child {
	font-size: 128.5%;
	letter-spacing: -0.04em;
	line-height: 1.72;
	margin-bottom: 40px;
	text-align: left;
}

/* Flow
------------------------ */
.flow {
	padding: 105px 0 125px;
}

.flow .inner {
	margin: 0 auto;
	width: 940px;
}

.flow h2 {
	border-bottom: 1px dotted #27467f;
	line-height: 1;
	margin-bottom: 50px;
	padding-bottom: 22px;
}

.flow h2 img {
	margin: 0 auto;
}

.flow-body li {
	padding: 40px 40px 26px 30px;
}

.flow-body li h3 {
	float: left;
	margin-right: 28px;
}

.flow-body li .detail {
	overflow: hidden;
	padding-top: 5px;
	zoom: 1;
}

.flow-body li .detail h4 {
	border-bottom: 1px dotted #27467f;
	font-size: 192%;
	font-weight: bold;
	line-height: 1;
	margin-bottom: 18px;
	padding-bottom: 10px;
	text-align: left;
}

.flow-body li .detail p {
	font-size: 114%;
	letter-spacing: -0.04em;
	line-height: 1.56;
	padding-right: 100px;
	text-align: left;
}

.flow-body .odd {
	background: #bfe3f9 url(../img/bg_odd.gif) no-repeat 63px top;
}

.flow-body .even {
	background: #97c7f5 url(../img/bg_even.gif) no-repeat 63px top;
}

.flow-body li:first-child {
	background-image: none;
	padding-top: 32px;
}

/* Case
------------------------ */
.case {
	background: #293543;
	padding: 105px 0 130px;
}

.case .inner {
	margin: 0 auto;
	width: 940px;
}

.case h2 {
	border-bottom: 1px dotted #c1b882;
	line-height: 1;
	margin-bottom: 35px;
	padding-bottom: 22px;
}

.case h2 img {
	margin: 0 auto;
}

.case .item {
	background: #fff;
	margin-top: 50px;
}

.case .item:first-child {
	margin-top: 0;
} 

.case .item h3 {
	background: #e8e8c5;
	font-size: 200%;
	line-height: 65px;
	text-align: center;
}

.case .item h3 span {
	font-size: 143%;
}

.case .item .body {
	margin: 0 auto;
	padding: 28px 0 32px;
	width: 670px;
}

.case .item .body h4 {
	font-size: 185%;
	font-weight: bold;
	line-height: 1;
	margin-bottom: 22px;
}

.case .item .body p {
	font-size: 114%;
	letter-spacing: -0.07em;
	line-height: 1.66;
	text-align: left;
}

.case .item .body p strong {
	color: #27467f;
}

/* Bottom lead
------------------------ */
.bottom-lead {
	background: url(../img/bg_slush.gif) repeat;
	padding: 48px 0 45px;
}

.bottom-lead p {
	color: #fff;
	font-size: 210%;
	font-weight: bold;
	line-height: 1.4;
}

.bottom-lead.sp p {
	color: #fff;
	font-size: 180%;
	font-weight: bold;
	line-height: 1.4;
}

/* Offer
------------------------ */
.offer {
	padding: 45px 0 50px;
}

.offer ul {
	margin: 0 auto;
	width: 662px;
}

.offer li {
	font-size: 92%;
	line-height: 1.7;
	margin-left: 1em;
	text-align: left;
	text-indent: -1em;
}

/* Link
------------------------ */
ul.link-inner {
    list-style: none;
    text-align: center;
    margin: 0 auto;
    width: 940px;
}

ul.link-inner li {
    float: left;
    width: 300px;
    height: 75px;
}

ul.link-inner li a,
.consultation a {
    display: block;
    overflow: hidden;
    width: 300px;
    height: 0 !important;
    height/**/: 75px;
    padding-top: 75px;
    background-image: url(../img/btn_01.png);
    background-repeat: no-repeat;
    outline: none;
    text-decoration: none;
}

ul.link-inner li.purchase a {
    background-image: url(../img/btn_01.png);
}

ul.link-inner li.sale a {
    background-image: url(../img/btn_02.png);
}

ul.link-inner li.others a {
    background-image: url(../img/btn_03.png);
}

.consultation {
	margin: 12px auto 0;
	width: 630px;
}

.consultation a {
    background-image: url(../img/btn_04.png);
	width: 630px;
}

ul.link-inner li a,
.consultation a {
    display: block;
    text-decoration: none;
    filter: alpha(opacity=100);
    -khtml-opacity: 1;
    -moz-opacity: 1;
    opacity: 1;
    filter: 1;
}

ul.link-inner li a:hover,
.consultation a:hover {
    text-decoration: none;
    filter: alpha(opacity=80);
    -khtml-opacity: 0.8;
    -moz-opacity: 0.8;
    opacity: 0.8;
    filter: 0.8;
}

:hover {
    transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
}


/* Link-2
------------------------ */

.link-2 {
    padding: 12px 0 40px;
}



/* CONTACT
---------------------------------------------- */

.contact {
    width: 100%;
    position: relative;
    text-align: center;
    z-index: 102;
}


/* Mail
----------------------------- */

.contact-mail-wrap {
    width: 100%;
    position: relative;
    text-align: center;
    background: #323e52 url(../img/bg_contact.gif) left top repeat;
}

.contact-mail-inner {
    width: 940px;
    margin: 0 auto;
    padding: 60px 0 30px 0;
    color: #c1b882;
}

.contact-mail-inner .text {
    margin: 24px auto 0;
    margin-bottom: 0;
}

.contact-mail-inner .text img {
	margin: 0 auto;
}

/* Tel
----------------------------- */

.contact-tel-wrap {
    width: 100%;
    position: relative;
    text-align: center;
    background: #4d4e54 url(../img/bg_tel.gif) left top repeat;
}

.contact-tel-inner {
    width: 940px;
    margin: 0 auto;
    padding: 60px 0;
    color: #c1b882;
}

.contact-tel-inner .text {
    margin: 30px auto;
    margin-bottom: 0;
}



/* Footer
---------------------------------------------- */

.footer {
    width: 100%;
    position: relative;
    z-index: 1000;
}

.logo-footer {
    width: 100%;
    padding: 35px 0;
    background: #000;
}

footer .solution-logo {
    width: 100%;
    padding: 20px 0;
    background: #4d4e54 url(../img/bg_footer_solution.jpg) left top repeat;
}

.solution-logo-inner {
    width: 300px;
    margin: 0 auto;
    padding: 5px 0;
}


/* 
---------------------------------------------- */

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

.cf:after {
    clear: both;
}


/* For IE 6/7 (trigger hasLayout) */

.cf {
    *zoom: 1;
}

.mr0 {
    margin-right: 0px;
}

.mr8 {
    margin-right: 8px;
}

.mr10 {
    margin-right: 10px;
}

.mr15 {
    margin-right: 15px;
}

.mr20 {
    margin-right: 20px;
}

.mr30 {
    margin-right: 30px;
}

.mr40 {
    margin-right: 40px;
}

.mr50 {
    margin-right: 50px;
}

p.pc {
    display: block;
}

p.sp {
    display: none;
}


/* ---------------------------------------------------------------------

__Media Query

--------------------------------------------------------------------- */

@media only screen and (max-width: 960px) {
    /* SP */
    p.pc {
        display: none;
    }
    p.sp {
        display: block;
    }
    .pc {
        display: none;
    }
    .sp {
        display: block;
    }
    /* Header
	------------------------------------ */
    ul.link-inner {
        width: 100%;
    }
    ul.link-inner li {
        float: none;
        margin: 20px auto;
    }
    .header {
        width: 100%;
        height: 110px;
    }
    h1.logo-inner a {
        width: 180px;
    }
    h2.solution-logo-inner {
        width: 300px;
    }
    h3.top-txt {
        width: 600px;
    }
	.consultation {
		margin: 12px auto 0;
		width: 580px;
	}

	.consultation a {
		background-image: url(../img/btn_04.png);
		background-size: 100% auto;
		width: 580px;
	}

	/* Main visual
	------------------------ */

	.mainvisual {
		height: auto;
		margin-bottom: 10px;
		padding: 20px 0;
	}

	/* Validate text
	------------------------ */
	.validate-text {
		margin-bottom: 30px;
		padding: 0 15px 28px;
	}

	.validate-text .inner {
		width: 100%;
	}

	.validate-text p:first-child {
		margin-bottom: 30px;
	}
	
	.validate-text p:first-child br {
		display: none;
	}

	/* Flow
	------------------------ */
	.flow {
		background: #f3fbfe;
		padding: 5px 5px 0;
	}

	.flow .inner {
		margin: 0 auto;
		width: 100%;
	}

	.flow h2 {
		background: #fff;
		border: 1px solid #6b8893;
		margin-bottom: 0;
		padding: 16px 34px;
		position: relative;
	}

	.flow h2 img {
		margin: 0;
	}
	
	.flow h2::after {
		background: url(../img/sp/icon_open.gif) no-repeat left top;
		content: "";
		display: block;
		height: 30px;
		margin-top: -15px;
		position: absolute;
		right: 30px;
		top: 50%;
		width: 30px;
	}
	
	.flow h2.on::after {
		background: url(../img/sp/icon_close.gif) no-repeat left top;
	}
	
	.flow .hide {
		display: none;
	}

	.flow-body li {
		padding: 40px 20px 26px;
	}

	.flow-body li .detail p {
		padding-right: 0;
	}

	.flow-body .odd {
		background: #bfe3f9 url(../img/bg_odd.gif) no-repeat 53px top;
	}

	.flow-body .even {
		background: #97c7f5 url(../img/bg_even.gif) no-repeat 53px top;
	}

	.flow-body li:first-child {
		background-image: none;
		padding-top: 32px;
	}

	/* Case
	------------------------ */
	.case {
		background: #f3fbfe;
		padding: 0 5px;
	}

	.case .inner {
		margin: 0 auto;
		width: 100%;
	}

	.case h2 {
		background: #fff;
		border: 1px solid #6b8893;
		margin-bottom: 0;
		padding: 16px 34px;
		position: relative;
	}

	.case h2 img {
		margin: 0;
	}
	
	.case h2::after {
		background: url(../img/sp/icon_open.gif) no-repeat left top;
		content: "";
		display: block;
		height: 30px;
		margin-top: -15px;
		position: absolute;
		right: 30px;
		top: 50%;
		width: 30px;
	}

	.case h2.on::after {
		background: url(../img/sp/icon_close.gif) no-repeat left top;
	}

	.case .hide {
		display: none;
	}
	
	.cases {
		background: #293543;
		padding: 30px 20px;
	}

	.case .item {
		margin-top: 12px;
	}

	.case .item:first-child {
		margin-top: 0;
	} 

	.case .item .body {
		padding: 28px 20px 32px;
		width: 100%;
	}

	.case .item .body h4 {
		line-height: 1;
		margin-bottom: 22px;
	}

	/* Bottom lead
	------------------------ */
	.bottom-lead {
		background: url(../img/bg_slush.gif) repeat;
		padding: 26px 40px;
	}

	.bottom-lead img {
		margin: 0 auto;
	}

	/* Offer
	------------------------ */
	.offer {
		background: #f3fbfe;
		padding: 60px 30px;
	}
	
	.offer ul {
		width: auto;
	}

    /* Contact
	------------------------------------ */
    .contact-mail-inner, .contact-tel-inner {
        width: 100%;
    }
    .contact-mail-inner .text {
        font-size: 16px;
        line-height: 1.8em;
    }
}