@charset "utf-8";


* { float: left; width: 100%; box-sizing: border-box; padding: 0; margin: 0; }
body { word-break: break-all; font-family: Meiryo, "メイリオ", "MS PGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Helvetica, Arial, sans-serif; }
html { color: #003650; line-height: 1.4; }
img { border: 0; }
a:hover img { filter: alpha( opacity=70 ); opacity: 0.70; -moz-opacity: 0.70; }
li { list-style: none; }
a { color: #003650; }
a:hover { text-decoration: none; }


/* フッター ------------- */
.footer_list { background: #003650; padding: 14px 0; }
.footer_list li { width: 50%; font-size: 11px; padding: 6px 0; }
.footer_list li a h4 { color: #ffffff; font-weight: normal; }
.footer_list li a:hover h4 { color: #f4cd35; }
.footer_list li:nth-child(odd) { text-align: right; padding-right: 15px; }
#copy div { font-size: 9px; text-align: center; font-weight: bold; background: #b5dddf; padding: 8px 0; }


/* フッターコンテンツ ------------- */
.contents_ttl { background: #003650; padding: 10px 0 8px 0; margin-bottom: 20px; }
.contents_ttl h5 { font-size: 17px; color: #ffffff; text-align: center; }

.contents_text { float: left; width: 90%; font-size: 13px; line-height: 1.6; margin: 0 5% 25px 5%; }
.contents_text img { margin: 5px; }
.contents_text * { float: none; width: auto; margin: 0 auto; }
.contents_text hr { float: left; width: 100%; border: 1px dashed #dceeee; margin: 20px 0; }

.btn { float: left; width: 60%; text-align: center; border: 2px solid #d9508a; border-radius: 8px; padding: 10px 0 8px 0; margin: 5px 20%; }
.btn a { font-size: 15px; color: #003650; font-weight: bold; }

.btn2 { float: left; width: 70%; text-align: center; border: 1px solid #003650; border-radius: 8px; padding: 12px; margin: 10px 15% 20px 15%; }
.btn2 a { font-size: 18px; color: #003650; font-weight: bold; border-bottom: double; }

.btn3, .send_btn, .more_btn { float: left; width: 70%; text-align: center; border: 2px solid #003650; border-radius: 8px; background: #f4cd35; padding: 12px; margin: 5px 15%; }
.btn3 a, .send_btn a, .more_btn a { font-size: 15px; color: #003650; font-weight: bold; }

.tokutei { float: left; width: 99%; border: 1px solid #cccccc; border-radius: 8px; padding: 15px; margin: 5px 0.5%; }
.tokutei th { float: left; font-size: 14px; background: linear-gradient(transparent 70%, #fffaba 70%); margin: 5px 0 8px 0; }
.tokutei td { float: left; width: 100%; }
.tokutei td a { text-decoration: underline; }


/* 一覧に戻る ------------- */
.cate_list { padding: 0 5% 30px 5%; }
.cate_list a h4 { width: 70%; font-size: 15px; color: #003650; text-align: center; border: 2px solid #003650; padding: 10px 0 8px 0; margin: 0 15%; }
.cate_list a h4:hover { color: #ffffff; background: #003650; }


/*--------------------
トップページ
--------------------*/
.logo { background: url(/upimages/back.jpg) no-repeat; background-position: left top; background-size: 100% auto; padding: 8px 0 10px 0; }
.logo img { width: 80%; margin: 10px 10%; }
.logo p { font-size: 12px; text-align: center; font-weight: bold; }

.new { background: #003650; }
.new p { font-size: 12px; color: #ffffff; text-align: center; }
.new p img { width: 36%; margin: 15px 32% 6px 32%; }
.new ul { padding: 5px 1% 12px 3%; }
.new ul li { width: 31.333%; background: #ffffff; padding: 5px; margin: 0 2% 8px 0; }

.new p:nth-child(2) { -webkit-animation:blink 1.5s ease-in-out infinite alternate; -moz-animation:blink 1.5s ease-in-out infinite alternate; animation:blink 1.5s ease-in-out infinite alternate; }
@-webkit-keyframes blink { 0% {opacity:0;} 100% {opacity:1;} }
@-moz-keyframes blink { 0% {opacity:0;} 100% {opacity:1;} }
@keyframes blink { 0% {opacity:0;} 100% {opacity:1;} }

.rank { background: linear-gradient(#b5dddf, #ffffff); }
.rank p img { padding: 0 3%; }
.rank ul { padding: 0 2% 0 4%; }
.rank ul li { position: relative; width: 31.333%; background: #ffffff; border: 1px solid #dceeee; padding: 8px; margin-right: 2%; }
.rank ul li img:nth-child(2) { position: absolute; top: -8px; left: -8px; width: 25%; }

.cate { width: 94%; margin: 12px 3% 15px 3%; }
.cate p { border-bottom: 3px solid #b5dddf; }
.cate p img { width: 14%; margin: 0 43% 3px 43%; }
.cate ul li { width: 50%; border-bottom: 1px dotted #003650; padding: 10px 0 8px 0; }
.cate ul li:nth-child(even) { border-left: 1px dotted #003650; padding-left: 12px; }
.cate ul li a { display: block; position: relative; font-size: 13px; text-decoration: none; font-weight: bold; }
.cate ul li a:hover { color: #f4cd35; }
.cate ul li a:before { content: ''; display: inline-block; width: 0; height: 0; margin-right: 3px; margin-left: 5px; border: transparent solid 5px; border-left-color: #f4cd35; }

.news { width: 94%; margin: 0 3%; }
.news p { border-bottom: 3px solid #b5dddf; }
.news p img { width: 18%; margin: 0 41% 3px 41%; }
.news ul li a { width: 100%; font-size: 13px; text-decoration: none; font-weight: bold; border-bottom: dotted 1px #003650; padding: 9px 0 7px 0; }
.news ul li a:hover { color: #f4cd35; }
.news ul li a:after { display: block; content: ""; position: absolute; top: 50%; right: 0; width: 6px; height: 6px; margin: -6px 0 0 0; border-top: solid 2px #f4cd35; border-right: solid 2px #f4cd35; -webkit-transform: rotate(45deg); transform: rotate(45deg); }

.logo_u { width: 94%; margin: 15px 3% 0 3%; }


/*--------------------
一覧ページ
--------------------*/
.list { background: linear-gradient(#b5dddf, #ffffff); }
.list p { position: relative; display: inline-block; width: 94%; font-size: 17px; color: #ffffff; font-weight: bold; text-align: center; background: #003650; padding: 10px 0 8px 0; margin: 12px 3% 0 3%; }
.list p:before { content: ""; position: absolute; top: 100%; left: 50%; margin-left: -8px; border: 8px solid transparent; border-top: 8px solid #003650; }
.list ul { padding: 18px 1.5% 15px 3%; }
.list li { width: 33.333%; font-size: 12px; text-align: center; padding: 0 1.5% 8px 0; }
.list li a { text-decoration: none; }
.list li img { width: 100%; padding: 8px; background: #ffffff; margin: 0; }


/*--------------------
詳細ページ
--------------------*/
.page { text-align: center; background: linear-gradient(#b5dddf, #ffffff); }
.page p { position: relative; display: inline-block; width: 94%; font-size: 18px; color: #003650; font-weight: bold; text-align: center; background: #ffffff; padding: 10px 0 8px 0; margin: 12px 3% 10px 3%; }
.page p:before { content: ""; position: absolute; top: 100%; left: 50%; margin-left: -8px; border: 8px solid transparent; border-top: 8px solid #ffffff; }
.download { padding: 5px 18%; }
.page img { padding: 0 15%; }
.back { font-size: 13px; font-weight: bold; text-decoration: underline; padding: 12px 0 15px 0; }