@charset "utf-8";

/* =============================================================================
    Reset style
   ========================================================================== */
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, 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 }
body { line-height: 1 }
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block }
nav ul { list-style: none }
blockquote, q { quotes: none }
blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none }
a { margin: 0; padding: 0; font-size: 100%; vertical-align: baseline; background: transparent }
ins { background-color: #ff9; color: #000; text-decoration: none }
mark { background-color: #ff9; color: #000; font-style: italic; font-weight: bold }
del { text-decoration: line-through }
abbr[title], dfn[title] { border-bottom: 1px dotted; cursor: help }
table { border-collapse: collapse; border-spacing: 0 }
hr { display: block; height: 1px; border: 0; border-top: 1px solid #cccccc; margin: 1em 0; padding: 0 }


/* =============================================================================
    Basic style
   ========================================================================== */

/*
 * body InitialStyle
 */
body { -webkit-text-size-adjust: none; background: #fff; }

/*
 * Wrapper InitialStyle
 */
#wrapper { position: relative; margin: 0 auto; overflow: hidden; background:#fff; }

/*
 * Inner InitialStyle
 */
.inner { width:1200px; margin: 0 auto; padding: 0; position:relative; }


/* =============================================================================
   Image
   ========================================================================== */

img { vertical-align: bottom; max-width :100%; }

/* Image center */
.img-center { display:block; margin:0 auto; }


/* =============================================================================
   Common Style
   ========================================================================== */

table { font-size:inherit;font:100%;}

pre, code, kbd, samp, tt { font-family: monospace; *font-size: 100%; font: 115% monospace; line-height: 150%; }

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

input,textarea,select { *font-size:100%; }

ul, li { list-style: none;}

input[type="text"],input[type="button"],input[type="submit"] { -webkit-appearance: none; border-radius: 0; }

button { background-color:white; border:none; padding: 0; }

/*
 * box-sizing
 */
div,p,dl,dt,dd,ol,ul,li,h1,h2,h3,h4,h5,h6,form,input,button,textarea,table,tr,th,td,article,aside,header,footer,section,nav,a{ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }


/* =============================================================================
   Typography
   ========================================================================== */

body { color: #333; letter-spacing: 0px; font-family:'Noto Sans JP', "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", 'Hiragino Kaku Gothic Pro', "メイリオ", 'Meiryo', "ＭＳ Ｐゴシック", 'MS PGothic', Helvetica, Arial, sans-serif;  font-weight: 300;}

p { line-height: 1.6; text-align: left;}

li,dt, dd { line-height: 1.6; }

.minchou { font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif; }

.yumin { font-family: "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", 'Hiragino Mincho Pro', 'MS Mincho','HiraMinProN-W3', serif;}

.yugo { font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic";}

.century{ font-family: "Century Gothic", Arial, sans-serif;}

h1,h2,h3,h4,h5,h6 { font-weight:300; line-height: 1.4; }

a { color:inherit; text-decoration:none; -webkit-tap-highlight-color: rgba(0, 0, 0, 0);　tap-highlight-color: rgba(0, 0, 0, 0); }

input[type="text"],input[type="button"],input[type="submit"] { -webkit-appearance: none; border-radius: 0; }

button { background-color:white; border:none; padding: 0; }

.num {font-family: arial; }
/*
 * convenient styles
 */
.ta-c { text-align:center; }
.ta-l { text-align:left; }
.ta-r { text-align:right; }

.normal { font-weight:normal; }
.bold,.fw-bold { font-weight:bold; }
.fw-200,.fw-thin { font-weight: 200; }
.fw-300,.fw-light { font-weight: 300; }
.fw-400,.fw-regular { font-weight: 400; }
.fw-500,.fw-medium { font-weight: 500; }
.fw-600 { font-weight: 600; }

/*
 * color
 */
.white { color:#fff; }
.black { color:#000; }

/*
 * letter-spacing
 */
p,li,dt,dd,th,td { letter-spacing: .035em; }
.xs-spacing { letter-spacing:.05rem; }
.s-spacing { letter-spacing:.1rem; }
.m-spacing { letter-spacing:.15rem; }
.l-spacing  { letter-spacing:.2rem; }

/*
 * line-height
 */
.line16 { line-height:1.6; }
.line17 { line-height:1.7; }
.line18 { line-height:1.8; }
.line19 { line-height:1.9; }
.line20 { line-height:2; }


/**
 *
 * Enter the font size
 * pattern to be used in this coding.
 *
 */
.fs-12 { font-size:12px; }
.fs-14 { font-size:14px; }
.fs-16 { font-size:16px; }
.fs-18 { font-size:18px; }
.fs-20 { font-size:20px; }
.fs-22 { font-size:22px; }
.fs-24 { font-size:24px; }
.fs-25 { font-size:25px; }
.fs-26 { font-size:26px; }
.fs-28 { font-size:28px; }
.fs-30 { font-size:30px; }
.fs-32 { font-size:32px; }
.fs-34 { font-size:34px; }
.fs-35 { font-size:35px; }
.fs-36 { font-size:36px; }
.fs-38 { font-size:38px; }
.fs-40 { font-size:40px; }
.fs-42 { font-size:42px; }
.fs-43 { font-size:43px; }
.fs-44 { font-size:44px; }
.fs-46 { font-size:46px; }
.fs-48 { font-size:48px; }
.fs-50 { font-size:50px; }
.fs-52 { font-size:52px; }
.fs-54 { font-size:54px; }
.fs-56 { font-size:56px; }
.fs-56 { font-size:58px; }
.fs-60 { font-size:60px; }
.fs-62 { font-size:62px; }
.fs-64 { font-size:64px; }
.fs-80 { font-size:80px; }
.fs-88 { font-size:88px; }

@media screen and (max-width: 768px) {
.fs-12 { font-size:.12rem; }
.fs-14 { font-size:.14rem; }
.fs-16 { font-size:.16rem; }
.fs-18 { font-size:.18rem; }
.fs-20 { font-size:.2rem; }
.fs-22 { font-size:.22rem; }
.fs-24 { font-size:.24rem; }
.fs-25 { font-size:.25rem; }
.fs-26 { font-size:.26rem; }
.fs-28 { font-size:.28rem; }
.fs-30 { font-size:.3rem; }
.fs-32 { font-size:.32rem; }
.fs-34 { font-size:.34rem; }
.fs-35 { font-size:.35rem; }
.fs-36 { font-size:.36rem; }
.fs-38 { font-size:.38rem; }
.fs-40 { font-size:.40rem; }
.fs-42 { font-size:.42rem; }
.fs-43 { font-size:.43rem; }
.fs-44 { font-size:.44rem; }
.fs-46 { font-size:.46rem; }
.fs-48 { font-size:.48rem; }
.fs-50 { font-size:.5rem; }
.fs-52 { font-size:.52rem; }
.fs-54 { font-size:.54rem; }
.fs-56 { font-size:.56rem; }
.fs-56 { font-size:.58rem; }
.fs-60 { font-size:.6rem; }
.fs-62 { font-size:.62rem; }
.fs-64 { font-size:.64rem; }
.fs-80 { font-size:.8rem; }
.fs-88 { font-size:.88rem; }
}

/* =============================================================================
    Layout style
   ========================================================================== */

/* Header */
#header { width:100%; }

/* Footer */
#footer { width:100%; }

/* Container */
#container { width:100%; }

/*
 * display
 */
.block { display: block; }
.inline { display: inline; }
.inline-block { display: inline-block; }


/*
 * position styles
 */
.relative { position:relative; }
.absolute { position: absolute; }
.front-position { position:relative; z-index:1; }


/*
 * flex box
 */
.flex { display: flex; display: -webkit-flex; }
.f-wrap { flex-wrap: wrap; -ms-flex-wrap: wrap; -moz-flex-wrap: wrap; -webkit-flex-wrap: wrap; }
.f-between { justify-content: space-between; -webkit-justify-content: space-between; }
.flex-list { display: flex; display: -webkit-flex; flex-wrap: wrap; -ms-flex-wrap: wrap; -moz-flex-wrap: wrap; -webkit-flex-wrap: wrap; justify-content: space-between; -webkit-justify-content: space-between; }
.align-center{align-items:center;}
.justify-center{justify-content:center;}
.flex-center{display:flex;display:-webkit-flex;justify-content:center;-ms-flex-pack:center;align-items:center;-ms-flex-align:center;}


/* =============================================================================
    Others
   ========================================================================== */

/* Header fix */
.fixed { position:fixed; left:0; top:0; z-index:9999; }

.bg-white { background: #fff; }
.bg-black { background: #000; }
/*
 * clearfix
 */
.clearfix:after { content: ""; display: block; height: 0; clear: both; visibility: hidden; }

@media screen and (min-width: 768px) {
/*
 * hover effect
 */
.u-target { transition: opacity .3s; }
.u-target:hover { opacity: .8; filter: alpha(opacity=80); -ms-filter: "alpha(opacity=80)"; cursor: pointer; }
}
