@charset "shift_jis";
@import url("./css/tables.css");
@import url("./css/commonstyles.css");
@import url("./css/textstyles.css");
html {
  font-family: sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%; }

body {
  margin: 0; }

article, aside, details, figcaption, figure, footer, header, main, menu, nav, section, summary {
  display: block; }

audio, canvas, progress, video {
  display: inline-block; }

audio:not([controls]) {
  display: none;
  height: 0; }

progress {
  vertical-align: baseline; }

template, [hidden] {
  display: none; }

a {
  background-color: transparent;
  -webkit-text-decoration-skip: objects; }
  a:active, a:hover {
    outline-width: 0; }

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted; }

b, strong {
  font-weight: inherit; }

b, strong {
  font-weight: bolder; }

dfn {
  font-style: italic; }

h1 {
  font-size: 2em;
  margin: 0.67em 0; }

mark {
  background-color: #ff0;
  color: #000; }

small {
  font-size: 80%; }

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

img {
  border-style: none; }

svg:not(:root) {
  overflow: hidden; }

code, kbd, pre, samp {
  font-family: monospace, monospace;
  font-size: 1em; }

figure {
  margin: 1em 40px; }

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible; }

button, input, select, textarea {
  font: inherit;
  margin: 0; }

optgroup {
  font-weight: bold; }

button, input {
  overflow: visible; }

button, select {
  text-transform: none; }

button, html [type="button"], [type="reset"], [type="submit"] {
  -webkit-appearance: button; }

button::-moz-focus-inner, [type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

button:-moz-focusring, [type="button"]:-moz-focusring, [type="reset"]:-moz-focusring, [type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal; }

textarea {
  overflow: auto; }

[type="checkbox"], [type="radio"] {
  box-sizing: border-box;
  padding: 0; }

[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button {
  height: auto; }

[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px; }
  [type="search"]::-webkit-search-cancel-button, [type="search"]::-webkit-search-decoration {
    -webkit-appearance: none; }

::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54; }

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit; }

/*
==================================================
基本スタイル
==================================================
*/
html {
  font-size: 62.5%; }

body {
  background-color: #fff;
  color: #333;
  font-family: "游ゴシック Medium", "Yu Gothic Medium", YuGothic, sans-serif;
  font-size: 1.6rem;
  line-height: 1.75;
  text-align: center;
  -webkit-text-size-adjust: 100%; }

#top h1 a, #whatsnew ul time {
  font-family: 'Palatino Linotype', 'Palatino', "游明朝", "Yu Mincho", YuMincho, Palatino-Roman, serif;
  font-weight: 600; }

.user1::before, .user2::before, .question1::before, .answer1::before, .question2::before, .answer2::before, #footer small, #whatsnew .title, #entrylist h4 {
  font-family: 'Palatino Linotype', 'Palatino', "游明朝", "Yu Mincho", YuMincho, Palatino-Roman, serif; }

#header .title {
  font-family: "游明朝", "Yu Mincho", YuMincho, Palatino-Roman, serif;
  font-weight: 600; }

div[id$="menu"] .title, div[id$="menu"] .menuitem > h4 {
  font-family: "游明朝", "Yu Mincho", YuMincho, Palatino-Roman, serif;
  font-weight: 600; }

.rank .more span a, #main ol > li::before {
  font-family: "游明朝", "Yu Mincho", YuMincho, Palatino-Roman, serif;
  font-weight: 600; }

div[id$="menu"] div[id^="space"] ol > li:before {
  font-family: "游明朝", "Yu Mincho", YuMincho, Palatino-Roman, serif;
  font-weight: 600; }
div[id^="text"]::after, div[id^="space"]::after {
  content: "";
  display: block;
  clear: both; }

h1, h2, h3 {
  clear: both; }

h2, h3, h4, h5, h6 {
  overflow: hidden; }

.clear {
  clear: both;
  font-size: 1px;
  line-height: 0; }

p {
  margin: 0; }

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

/* メニュー内画像高さ調整 */
#menu .menulist ul li a img, #rmenu .menulist ul li a img {
  max-height: 360px; }

/* ボックス色調整 */
.ylwbox {
  background-color: #FDF9E8;
  border: 4px solid #EAC43F; }

@media screen and (min-width: 768px) {
  #main .nmlbox, #main .dottbox, #main .ylwbox, #main .graybg {
    padding: 20px 4%;
    box-sizing: border-box; } }
/* 画像位置調整 */
#main .topimg_right img, #main .topimg_left img {
  margin: 0; }
#main .fleximg1 img {
  min-height: 152px; }
#main div[class*="box"] > ul, #main div[class*="box"] > ol {
  margin-top: 4px !important;
  margin-bottom: 4px !important; }
#main div[class*="box"]:not(.menubox) > ul, #main div[class*="box"]:not(.menubox) > ol {
  margin-top: 4px !important;
  margin-bottom: 4px !important; }
#main :not(#whatsnew):not(#pagelist):not(#index_inner):not(#sitemaps):not(li) > ul {
  list-style: outside none none;
  margin: 10px 0;
  overflow: hidden;
  padding: 0;
  width: 100%; }

/* リスト
==================================================
*/
div[id$="menu"] div[id^="space"] ul {
  list-style: outside none none;
  margin: 10px 0;
  overflow: hidden;
  padding: 0;
  width: 100%; }

#main :not(#whatsnew):not(#pagelist):not(#index_inner):not(#sitemaps):not(li) > ul > li, div[id$="menu"] div[id^="space"] ul > li {
  margin: 5px 0;
  padding: 0 0 0 calc(26em/16);
  position: relative; }

#main :not(#whatsnew):not(#pagelist):not(#index_inner):not(#sitemaps):not(li) > ul > li::before, div[id$="menu"] div[id^="space"] ul > li:before {
  background-color: #333;
  content: '';
  height: calc(6em/16);
  left: calc(8em/16);
  position: absolute;
  top: calc(11em/16);
  width: calc(6em/16); }

#indexlist ul {
  width: 100%; }

#main ol, div[id$="menu"] div[id^="space"] ol {
  counter-reset: number;
  list-style: outside none none;
  margin: 10px 0;
  overflow: hidden;
  padding: 0;
  width: 100%; }

#main ol > li, div[id$="menu"] div[id^="space"] ol > li {
  display: flex;
  margin: 3px 0;
  position: relative; }

#index_inner ol > li {
  display: block !important; }

#main ol > li::before, div[id$="menu"] div[id^="space"] ol > li:before {
  color: #333;
  content: counter(number) ".";
  counter-increment: number;
  font-size: 1.8rem;
  font-weight: normal;
  line-height: 1;
  padding: 0.5rem; }

#main #index_inner > ol {
  padding-left: 8px !important;
  margin-right: 16px !important; }

#contents #index_inner > ol > li::before {
  padding: 0.4rem 0; }
#contents #index_inner > ol > li:nth-child(n+11)::before {
  letter-spacing: -1px; }
#contents #index_inner > ol > li:nth-child(n+101)::before {
  font-size: 1.7rem; }
#contents #index_inner > ol > li:nth-child(n+101) > a {
  padding-left: 0.6rem; }

#indexlist ul ol > li::before, #indexlist ol ol > li::before {
  padding: 0; }

/* リンク
==================================================
*/
a {
  color: #4887d9;
  transition: background-color .1s linear, border .1s linear, color .1s linear, opacity .1s linear, transform .1s linear; }
  a img {
    background: none; }
  a:hover img {
    opacity: 0.7;
    transition: opacity 0.3s ease-out; }

@media screen and (min-width: 1000px) {
  a:hover {
    opacity: 0.7;
    text-decoration: none; }

  #main a:hover, #menu a:hover, #rmenu a:hover, #pagetop a:hover {
    left: 1px;
    position: relative;
    top: 1px; } }
/*
==================================================
全体
==================================================
*/
/* レイアウト
==================================================
*/
#wrapper {
  overflow: hidden;
  position: relative;
  z-index: 0; }

#contents {
  display: flex;
  flex-wrap: wrap;
  position: relative; }

#column1 #contents {
  flex-direction: column;
  align-items: center; }

#siteNavi {
  color: #707070;
  font-size: 1rem;
  margin: 10px 0; }
  #siteNavi a {
    color: #707070; }
  #siteNavi br {
    display: none; }

@media screen and (min-width: 768px) {
  #contents {
    justify-content: space-around; } }
@media screen and (min-width: 1000px) {
  #contents {
    justify-content: center;
    padding-top: 16px;
    max-width: none !important;
    width: auto !important; }

  #siteNavi {
    font-size: 1.2rem;
    margin: 0 0 20px; } }
/* 検索ボックス
==================================================
*/
#searchbox {
  height: 100%;
  left: 0;
  letter-spacing: 0;
  line-height: 1;
  position: absolute;
  width: 100%; }
  #searchbox form {
    background-color: #000;
    border: none;
    box-sizing: border-box;
    display: flex;
    padding: 15px;
    position: relative;
    text-align: left;
    width: 100%;
    z-index: 1; }
    #searchbox form label[for="search-text"] {
      position: relative;
      width: 100%; }
      #searchbox form label[for="search-text"]::before {
        border-right: 1px dotted #000;
        bottom: 6px;
        content: '';
        right: 0;
        position: absolute;
        top: 6px;
        z-index: 1; }
    #searchbox form label[for="search-submit"] {
      position: relative; }
      #searchbox form label[for="search-submit"]::before {
        border: 2px solid #000;
        border-radius: 50%;
        box-sizing: border-box;
        content: '';
        height: 10px;
        left: 50%;
        margin-left: -6px;
        margin-top: -7px;
        position: absolute;
        top: 50%;
        width: 10px; }
      #searchbox form label[for="search-submit"]::after {
        background-color: #000;
        border-radius: 2px;
        content: '';
        height: 6px;
        left: 50%;
        margin-left: 3px;
        margin-top: 0;
        position: absolute;
        top: 50%;
        transform: rotate(-45deg);
        width: 2px; }
  #searchbox input {
    -webkit-appearance: none;
    border-radius: 0; }
    #searchbox input[type="text"], #searchbox input[type="search"] {
      background-color: #fff;
      border: none;
      box-sizing: border-box;
      color: #302c2c;
      cursor: auto;
      font-size: 1.6rem;
      height: 40px;
      line-height: 40px;
      padding: 0 12px;
      position: relative;
      width: 100%; }
    #searchbox input[type="submit"] {
      background-color: #fff;
      border: none;
      cursor: pointer;
      font-size: 1rem;
      height: 40px;
      overflow: hidden;
      padding: 0;
      text-indent: 200%;
      white-space: nowrap;
      width: 40px; }
  #searchbox .closebtn {
    background-color: rgba(0, 0, 0, 0.85);
    height: auto;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 0; }
    #searchbox .closebtn input {
      display: none; }

#searchtoggle #searchbtn {
  background-color: #262728;
  display: block;
  height: 40px;
  overflow: hidden;
  position: relative;
  text-indent: 200%;
  white-space: nowrap;
  width: 40px; }
  #searchtoggle #searchbtn::before {
    border: 2px solid #fff;
    border-radius: 50%;
    box-sizing: border-box;
    content: '';
    height: 10px;
    left: 50%;
    margin-left: -6px;
    margin-top: -7px;
    position: absolute;
    top: 50%;
    width: 10px; }
  #searchtoggle #searchbtn::after {
    background-color: #fff;
    border-radius: 2px;
    content: '';
    height: 6px;
    left: 50%;
    margin-left: 3px;
    margin-top: 0;
    position: absolute;
    top: 50%;
    transform: rotate(-45deg);
    width: 2px; }
#searchtoggle .closebtn {
  display: none;
  height: 40px;
  overflow: hidden;
  position: relative;
  width: 40px; }
  #searchtoggle .closebtn::before {
    border-top: 1px solid #fff;
    content: '';
    height: 0;
    left: 50%;
    margin-left: -10px;
    margin-top: -1px;
    position: absolute;
    top: 50%;
    width: 20px;
    transform: rotate(45deg); }
  #searchtoggle .closebtn::after {
    border-top: 1px solid #fff;
    content: '';
    height: 0;
    left: 50%;
    margin-left: -10px;
    margin-top: -1px;
    position: absolute;
    top: 50%;
    width: 20px;
    transform: rotate(45deg);
    transform: rotate(-45deg); }
  #searchtoggle .closebtn input {
    display: none; }

input#panelsearch[type="radio"] {
  display: none; }
  input#panelsearch[type="radio"] ~ #searchbox {
    opacity: 0;
    transition: opacity .1s linear, z-index .1s linear;
    z-index: -1; }
    input#panelsearch[type="radio"] ~ #searchbox form {
      opacity: 0;
      transition: transform 0.6s cubic-bezier(0.19, 1, 0.22, 1) 0.2s, opacity 0.1s linear 0.2s;
      transform: translateY(-10px); }
  input#panelsearch[type="radio"]:checked ~ #searchtoggle #searchbtn {
    display: none; }
  input#panelsearch[type="radio"]:checked ~ #searchtoggle .closebtn {
    display: block; }
  input#panelsearch[type="radio"]:checked ~ #searchbox {
    opacity: 1;
    z-index: 999; }
    input#panelsearch[type="radio"]:checked ~ #searchbox form {
      opacity: 1;
      transform: translateY(0); }

@media screen and (min-width: 1000px) {
  #searcharea {
    align-self: center;
    margin-left: auto; }

  #searchbox {
    background-color: #171717;
    display: flex;
    align-items: center;
    left: auto;
    right: 70px;
    top: 0;
    width: calc(100% - 70px); }
    #searchbox form {
      padding: 0; }
      #searchbox form label[for="search-submit"] {
        cursor: pointer; }
        #searchbox form label[for="search-submit"]::before, #searchbox form label[for="search-submit"]::after {
          transition: opacity .1s linear; }
        #searchbox form label[for="search-submit"]:hover::before, #searchbox form label[for="search-submit"]:hover::after {
          opacity: 0.6; }
    #searchbox input[type="text"]:focus, #searchbox input[type="search"]:focus {
      outline: 0; }
    #searchbox .closebtn {
      display: none; }

  #searchtoggle #searchbtn {
    cursor: pointer;
    height: 70px;
    width: 70px;
    transition: background-color .1s linear; }
    #searchtoggle #searchbtn:hover {
      background-color: #323435; }
  #searchtoggle .closebtn {
    cursor: pointer;
    height: 70px;
    width: 70px; }

  input#panelsearch[type="radio"] ~ #searchbox form {
    margin-left: auto;
    transition: width 0.4s cubic-bezier(0.19, 1, 0.22, 1) 0.1s, opacity 0.1s linear 0.1s;
    transform: translateY(0);
    width: 10%; }
  input#panelsearch[type="radio"]:checked ~ #searchbox form {
    width: 100%; } }
/* 回り込み・回り込み解除
==================================================
*/
.txt-img img {
  margin: 0 8px 8px 8px; }

.center {
  margin: 5px 0;
  text-align: center; }

.float-l {
  float: left; }

.float-r {
  float: right; }

.float-l img, .float-r img {
  margin-bottom: 20px; }

.float-l img {
  margin-right: 20px; }

.float-r img {
  margin-left: 20px; }

.clear, .FloatEnd {
  clear: both;
  font-size: 1px;
  height: 0;
  line-height: 0; }

@media screen and (max-width: 640px) {
  .txt-img {
    padding: 0 10px;
    text-align: center !important;
    box-sizing: border-box; }

  td .txt-img, th .txt-img {
    padding: 0; } }
/*
==================================================
トップ部分
==================================================
*/
/* トップ
==================================================
*/
#top {
  align-items: flex-end;
  background-color: #000;
  display: flex;
  flex-wrap: wrap;
  text-align: left; }
  #top > .inner {
    align-self: center;
    min-height: 40px;
    width: calc(100% - 80px); }
  #top h1 {
    box-sizing: border-box;
    font-size: 1.4rem;
    font-weight: normal;
    line-height: 1;
    margin: 0;
    padding: 10px;
    color: #fff; }
    #top h1 a {
      color: #fff;
      letter-spacing: 0.05em;
      line-height: 1.4;
      text-decoration: none; }
      #top h1 a img {
        max-height: 20px; }

@media screen and (min-width: 1000px) {
  #top .inner {
    margin: 0 auto;
    width: 1000px; }
  #top > .inner {
    max-width: none !important;
    width: 100% !important; }
  #top h1 {
    margin: 0 auto;
    padding: 15px 0;
    width: 1000px; }
    #top h1 a img {
      max-height: none; } }
@media screen and (min-width: 1000px) {
  #top h1 {
    max-width: 1000px;
    width: 1000px; } }
/* ヘッダー
==================================================
*/
#header {
  background-color: #000;
  overflow: hidden;
  position: relative;
  width: 100%; }
  #header > img {
    height: auto;
    width: 100%; }
  #header .title {
    bottom: 0;
    box-sizing: border-box;
    display: flex !important;
    justify-content: center;
    left: 0;
    margin: 0;
    overflow: visible;
    padding: 0;
    position: absolute;
    text-align: left;
    width: 100%;
    z-index: 0; }
    #header .title::after {
      background-color: rgba(0, 0, 0, 0.5);
      bottom: 0;
      content: '';
      left: 0;
      position: absolute;
      right: 0;
      top: 0;
      z-index: -1; }
    #header .title span {
      display: block;
      font-size: 1.5rem;
      letter-spacing: 3px;
      line-height: 1.5;
      margin: 0;
      padding: 2% 12px;
      width: auto; }
      #header .title span a {
        color: #fff;
        text-decoration: none; }

@media screen and (max-width: 767px) {
  #header .title #headerblurbox {
    display: none; }
  #header .title img {
    display: block; } }
@media screen and (min-width: 768px) {
  #header .title {
    left: -50%;
    overflow: hidden;
    padding: 0 50%;
    width: 200%; }
    #header .title::before {
      background-position: center bottom;
      background-repeat: no-repeat;
      background-size: cover;
      bottom: 0;
      content: '';
      filter: blur(10px);
      left: 25%;
      position: absolute;
      right: 0;
      top: 0;
      width: 50%;
      z-index: -1; }
    #header .title span {
      font-size: 2.8rem;
      line-height: 1.4;
      padding: 2% 16px; }
      #header .title span img {
        padding: 20px 30px;
        width: auto; }
    #header .title #headerblurbox {
      bottom: 0;
      left: 25%;
      position: absolute;
      width: 100%;
      z-index: -1; }
      #header .title #headerblurbox #headerblur {
        bottom: 0;
        position: absolute; } }
@media screen and (min-width: 1000px) {
  #header {
    margin: 0 auto;
    max-width: none !important;
    overflow: visible;
    width: auto !important;
    text-align: center; }
    #header > img {
      min-width: 1000px; }
    #header .title {
      justify-content: flex-start; }
      #header .title span {
        box-sizing: border-box;
        font-size: 3.2rem;
        margin: 0 auto;
        padding: 2% 30px;
        text-align: center;
        width: 1000px; }
        #header .title span img {
          padding: 30px; } }
@media screen and (min-width: 767px) {
  #headert #headertxt:first-child {
    top: 0;
    left: 0;
    position: relative;
    transform: unset;
    padding: 16px 20px;
    min-height: 160px;
    display: flex;
    flex-direction: column;
    justify-content: center; }

  #header #headertxt:first-child .title {
    left: 0;
    width: 100%;
    padding: 0 8px;
    position: relative; } }
/* トップメニュー
==================================================
*/
#topmenubox {
  flex-shrink: 0;
  margin-left: auto; }
  #topmenubox .inner {
    display: flex; }

#topmenu {
  box-sizing: border-box;
  left: 0;
  letter-spacing: 0;
  height: 100%;
  position: absolute;
  width: 100%; }
  #topmenu ul {
    background-color: #000;
    box-sizing: border-box;
    list-style: outside none none;
    margin: 0 0 0 50px;
    padding: 20px 30px;
    height: 100%;
    width: calc(100% - 50px); }
    #topmenu ul li {
      text-align: left; }
    #topmenu ul a {
      color: #fff;
      display: block;
      font-size: 1.3rem;
      line-height: 1.6;
      padding: 15px 0;
      text-decoration: none;
      text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3); }
      #topmenu ul a img {
        max-height: 60px; }
  #topmenu .closebtn {
    background-color: rgba(0, 0, 0, 0.85);
    height: 100%;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: -1; }
    #topmenu .closebtn input {
      display: none; }

/* メニュー表記ありの場合 */
#topmenutoggle #topmenubtn {
  box-sizing: border-box;
  display: block;
  height: 40px;
  overflow: hidden;
  position: relative;
  text-indent: 200%;
  white-space: nowrap;
  width: 40px; }
  #topmenutoggle #topmenubtn::before {
    border-bottom: 1px solid #fff;
    border-top: 1px solid #fff;
    box-sizing: border-box;
    content: '';
    height: 7px;
    left: 50%;
    margin-left: -9px;
    margin-top: -7px;
    position: absolute;
    top: 50%;
    width: 18px; }
  #topmenutoggle #topmenubtn::after {
    border-top: 1px solid #fff;
    content: '';
    height: 0;
    left: 50%;
    margin-left: -9px;
    margin-top: 5px;
    position: absolute;
    top: 50%;
    width: 18px; }
#topmenutoggle .closebtn {
  box-sizing: border-box;
  display: none;
  height: 40px;
  overflow: hidden;
  position: relative;
  width: 40px; }
  #topmenutoggle .closebtn::before {
    border-top: 1px solid #fff;
    content: '';
    height: 0;
    left: 50%;
    margin-left: -10px;
    margin-top: -1px;
    position: absolute;
    top: 50%;
    width: 20px;
    transform: rotate(45deg); }
  #topmenutoggle .closebtn::after {
    border-top: 1px solid #fff;
    content: '';
    height: 0;
    left: 50%;
    margin-left: -10px;
    margin-top: -1px;
    position: absolute;
    top: 50%;
    width: 20px;
    transform: rotate(45deg);
    transform: rotate(-45deg); }
  #topmenutoggle .closebtn input {
    display: none; }

input#panelmenu[type="radio"] {
  display: none; }
  input#panelmenu[type="radio"] ~ #topmenu {
    opacity: 0;
    transition: opacity .1s linear, z-index .1s linear;
    z-index: -1; }
    input#panelmenu[type="radio"] ~ #topmenu ul {
      transition: transform 0.6s cubic-bezier(0.19, 1, 0.22, 1);
      transform: translateX(100px); }
      input#panelmenu[type="radio"] ~ #topmenu ul li {
        opacity: 0;
        transition: transform 0.6s cubic-bezier(0.19, 1, 0.22, 1) 0.2s, opacity 0.1s linear 0.2s;
        transform: translateX(10px); }
  input#panelmenu[type="radio"]:checked ~ #topmenutoggle #topmenubtn {
    display: none; }
  input#panelmenu[type="radio"]:checked ~ #topmenutoggle .closebtn {
    display: block; }
  input#panelmenu[type="radio"]:checked ~ #topmenu {
    opacity: 1;
    z-index: 999; }
    input#panelmenu[type="radio"]:checked ~ #topmenu ul {
      transform: translateX(0); }
      input#panelmenu[type="radio"]:checked ~ #topmenu ul li {
        opacity: 1;
        transform: translateX(0); }

@media screen and (min-width: 1000px) {
  #topmenubox {
    background-color: #171717;
    border-top: 1px solid #272727;
    flex-shrink: 1;
    margin: 0;
    order: 2;
    max-width: none !important;
    width: 100% !important; }
    #topmenubox .inner {
      align-items: stretch;
      position: relative; }

  #topmenuarea {
    display: flex; }

  #topmenu {
    background-color: transparent;
    display: flex;
    height: auto;
    opacity: 1 !important;
    position: static;
    width: auto;
    z-index: auto !important; }
    #topmenu ul {
      background-color: transparent;
      display: flex;
      flex-wrap: wrap;
      height: auto;
      margin: 0;
      padding: 0;
      transform: translateX(0) !important;
      max-width: none !important;
      width: auto !important; }
      #topmenu ul li {
        display: flex;
        opacity: 1 !important;
        transform: translateX(0) !important; }
      #topmenu ul a {
        display: flex;
        align-items: center;
        font-size: 1.3rem;
        min-height: 70px;
        padding: 0 24px; }
        #topmenu ul a:hover {
          background-color: #242424;
          opacity: 1; }
    #topmenu .closebtn {
      display: none; }

  #topmenutoggle {
    display: none; } }
@media screen and (min-width: 768px) {
  #top {
    min-height: 52px; }
    #top h1 {
      margin: 0 auto; }

  #topmenubox {
    width: 50% !important;
    position: absolute;
    background: none;
    right: 0;
    top: 0;
    border: none; }
    #topmenubox > .inner {
      width: 100%;
      justify-content: flex-end;
      z-index: 10; }

  #searchtoggle #searchbtn {
    height: 50px;
    width: 50px; }

  #searchbox {
    max-width: 500px; }

  #searchtoggle .closebtn {
    height: 50px;
    width: 50px; }

  #searchbox .closebtn {
    height: auto; } }
/*
==================================================
メインコンテンツ
==================================================
*/
/* 記事領域
==================================================
*/
#main {
  background-color: #fff;
  box-sizing: border-box;
  overflow: hidden;
  padding: 10px;
  text-align: left;
  width: 100%;
  order: -1; }
  #main div[id^="text"] {
    margin-bottom: 10px; }

#space1, #space2 {
  margin-bottom: 10px; }

@media screen and (min-width: 768px) {
  #main {
    order: 0;
    padding: 25px; }
    #main div[id^="text"] {
      margin-bottom: 24px;
      overflow: hidden; }

  #space1, #space2 {
    margin-bottom: 24px;
    overflow: hidden; } }
/* 見出し
==================================================
*/
#main h2, #main h3 {
  border-bottom: 3px solid #333;
  margin: 0 0 10px;
  padding: 0; }
#main h2 span, #main h3 span {
  color: #333;
  display: block;
  font-size: 2rem;
  line-height: 1.5;
  padding: 10px 0; }
#main h2 a, #main h3 a {
  color: #333; }
#main h2 a:not([href]), #main h3 a:not([href]) {
  text-decoration: none; }
#main div[id^="text"] h2, #main div[id^="text"] h3 {
  margin: 10px 0; }
#main div[id^="space"] h2, #main div[id^="space"] h3 {
  margin: 10px 0; }
#main h4 {
  border-bottom: 1px solid #d6d6d6;
  color: #333;
  font-size: 1.8rem;
  line-height: 1.5;
  margin: 10px auto;
  padding: 9px 0;
  position: relative; }
  #main h4::before {
    border-bottom: 1px solid #d6d6d6;
    bottom: 2px;
    content: '';
    left: 0;
    position: absolute;
    width: 100%; }
#main h5 {
  color: #333;
  font-size: 1.7rem;
  line-height: 1.5;
  margin: 15px 0 10px;
  padding: 0 0 0 13px;
  position: relative; }
  #main h5::before {
    border-left: 4px solid #333;
    bottom: 2px;
    content: '';
    left: 0;
    position: absolute;
    top: 2px;
    width: 0; }
#main h6 {
  background-image: url(img/h6.png);
  background-position: 1px 6px;
  background-repeat: no-repeat;
  background-size: 8px auto;
  color: #333;
  font-size: 1.6rem;
  line-height: 1.6;
  margin: 8px auto;
  padding: 0 0 0 16px; }

#contents div:not(.menuitem):not(id) > h4:first-child, #contents div:not(.menuitem):not(id) > h5:first-child, #contents div:not(.menuitem):not(id) > h6:first-child {
  margin-top: 4px; }

#main blockquote {
  background-color: #f7f7f7;
  border: 2px solid #eeeeee;
  font-size: 1.6rem;
  line-height: 1.8;
  margin: 20px 0;
  padding: 15px 20px; }
  #main blockquote::before, #main blockquote::after {
    content: '”'; }

@media screen and (min-width: 768px) {
  #main h2, #main h3 {
    margin: 0 0 20px; }
  #main h2 span, #main h3 span {
    font-size: 2.8rem;
    line-height: 1.4;
    padding: 16px 0; }
  #main div[id^="text"] h2, #main div[id^="text"] h3 {
    margin: 20px 0; }
  #main div[id^="space"] h2, #main div[id^="space"] h3 {
    margin: 20px 0; }
  #main h4 {
    font-size: 2.5rem;
    line-height: 1.4;
    padding: 14px 4px; }
  #main h5 {
    font-size: 2.0rem;
    line-height: 1.5;
    padding: 0 0 0 18px; }
  #main h6 {
    font-size: 1.7rem;
    line-height: 1.5; }
  #main blockquote {
    padding: 25px 30px; } }
/*
==================================================
画像付きボックス
==================================================
*/
.alert, .accept, .attention, .thint {
  background-position: 14px 20px;
  background-size: 16px auto;
  border: none;
  font-size: 1.6rem;
  line-height: 1.8;
  margin: 15px 0;
  padding: 15px 15px 15px 56px;
  position: relative; }

.alert::before, .accept::before, .attention::before, .thint::before {
  border-left-style: solid;
  border-left-width: 1px;
  bottom: 14px;
  content: '';
  left: 43px;
  position: absolute;
  top: 14px; }

.alert.noimage, .accept.noimage, .attention.noimage, .thint.noimage {
  padding: 15px 20px; }

.alert.noimage::before, .accept.noimage::before, .attention.noimage::before, .thint.noimage::before {
  display: none; }

.alert {
  background-color: #fff3f7;
  color: #ce6785; }
  .alert::before {
    border-left-color: #eec2cf; }

.accept {
  background-color: #f2f9ef;
  color: #7ea761; }
  .accept::before {
    border-left-color: #cadcbd; }

.attention {
  background-color: #fef7e7;
  color: #de9d5a; }
  .attention::before {
    border-left-color: #f3d8b6; }

.thint {
  background-color: #eff6fc;
  color: #5883a6; }
  .thint::before {
    border-left-color: #bacede; }

@media screen and (min-width: 768px) {
  .alert, .accept, .attention, .thint {
    background-position: 28px 28px;
    background-size: 29px auto;
    margin: 20px 0;
    padding: 32px 20px 32px 112px; }

  .alert::before, .accept::before, .attention::before, .thint::before {
    left: 84px; }

  .alert.noimage, .accept.noimage, .attention.noimage, .thint.noimage {
    padding: 25px 30px; } }
.user1, .user2 {
  background-color: #f6f6f6;
  background-image: none;
  border: none;
  box-sizing: border-box;
  font-size: 1.6rem;
  line-height: 1.8;
  margin: 15px 0;
  overflow: visible;
  padding: 20px;
  position: relative;
  _height: auto; }

.user1::before, .user2::before {
  background-image: url(img/user1.png);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 100% auto;
  box-sizing: border-box;
  color: #fff;
  content: 'MAN';
  float: left;
  font-size: 12px;
  font-style: italic;
  height: 48px;
  line-height: 1;
  margin: -20px -20px 0 -20px;
  padding: 5px 0 0 8px;
  width: 81px; }

.user1.noimage, .user2.noimage {
  padding: 15px 20px; }

.user1.noimage::before {
  display: none; }

.user2.noimage::before {
  display: none; }
.user2::before {
  background-image: url(img/user2.png);
  content: 'WOMAN';
  padding: 5px 0 0 2px; }

@media screen and (min-width: 768px) {
  .user1, .user2 {
    margin: 20px 0;
    padding: 25px 30px; }

  .user1::before, .user2::before {
    font-size: 16px;
    height: 60px;
    margin: -25px -30px 0 -30px;
    padding: 7px 0 0 12px;
    width: 120px; }

  .user1.noimage {
    padding: 25px 30px; }

  .user2.noimage {
    padding: 25px 30px; }
  .user2::before {
    padding: 7px 0 0 6px; } }
/*
==================================================
FAQ
==================================================
*/
.question1, .answer1 {
  background-image: none;
  border: none;
  border-radius: 0;
  font-size: 1.6rem;
  line-height: 1.8;
  margin: 20px 0;
  overflow: hidden;
  padding: 10px 10px 10px 66px; }

.question1::before, .answer1::before {
  font-size: 2.6rem;
  font-weight: 300;
  left: 10px;
  line-height: 1;
  position: absolute;
  text-align: center;
  top: 13px;
  width: 2.6rem; }

.question1::after, .answer1::after {
  border-left-style: solid;
  border-left-width: 1px;
  bottom: 8px;
  content: '';
  left: 46px;
  position: absolute;
  top: 8px; }

.question1 {
  background-color: #4e5765;
  color: #fff;
  position: relative; }
  .question1::before {
    color: #fff;
    content: 'Q'; }
  .question1::after {
    border-left-color: #fff; }
  .question1 + .answer1 {
    margin-top: -20px; }

.answer1 {
  background-color: #fff;
  border: 1px solid #4e5765; }
  .answer1::before {
    color: #4e5765;
    content: 'A'; }
  .answer1::after {
    border-left-color: #4e5765; }

@media screen and (min-width: 768px) {
  .question1, .answer1 {
    padding: 20px 20px 20px 96px; }

  .question1::before, .answer1::before {
    font-size: 3.2rem;
    left: 20px;
    top: 20px;
    width: 3.2rem; }

  .question1::after, .answer1::after {
    bottom: 14px;
    left: 71px;
    top: 14px; } }
.question2, .answer2 {
  background-image: none;
  border: none;
  font-size: 1.6rem;
  line-height: 1.8;
  margin: 20px 0;
  padding: 4px 0 0 48px;
  position: relative; }

.question2::before, .answer2::before {
  color: #fff;
  content: '';
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.9rem;
  font-weight: 300;
  height: 36px;
  left: 0;
  position: absolute;
  top: 0;
  width: 36px; }

.question2::before {
  background-color: #3c4553;
  content: 'Q'; }
.question2 + .answer2 {
  margin-top: -5px; }

.answer2::before {
  background-color: #6d7685;
  content: 'A'; }

@media screen and (min-width: 768px) {
  .question2, .answer2 {
    margin: 30px 0; } }
/*
==================================================
サイドメニュー
==================================================
*/
/* メニュー
==================================================
*/
#menu, #rmenu {
  box-sizing: border-box;
  margin-top: 10px;
  overflow: hidden;
  text-align: left;
  width: 100%; }

#menu h4, #menu .subtitle, #menu .title {
  background-color: #f2f2f2;
  margin: 0;
  padding: 2px 0; }

#rmenu h4, #rmenu .subtitle, #rmenu .title {
  background-color: #f2f2f2;
  margin: 0;
  padding: 2px 0; }

#menu h4 span, #menu .subtitle span, #menu .title span {
  border-bottom: 1px solid #fff;
  border-top: 1px solid #fff;
  display: block;
  color: #444;
  font-size: 1.6rem;
  font-weight: normal;
  line-height: 1.5;
  padding: 13px 16px; }

#rmenu h4 span, #rmenu .subtitle span, #rmenu .title span {
  border-bottom: 1px solid #fff;
  border-top: 1px solid #fff;
  display: block;
  color: #444;
  font-size: 1.6rem;
  font-weight: normal;
  line-height: 1.5;
  padding: 13px 16px; }

#menu .menubox, #menu .menubox2 {
  background-color: #fff;
  margin: 0 0 10px;
  overflow: hidden; }

#rmenu .menubox, #rmenu .menubox2 {
  background-color: #fff;
  margin: 0 0 10px;
  overflow: hidden; }

#menu .menubox2 img, #rmenu .menubox2 img {
  margin-bottom: 5px; }

#menu .menulist ul, #rmenu .menulist ul {
  list-style: outside none none;
  margin: 0;
  padding: 0; }

#menu .menulist li, #rmenu .menulist li {
  line-height: 1;
  padding: 0; }

#menu .menulist li a, #rmenu .menulist li a {
  background-color: #fff;
  border-bottom: 1px solid #ececec;
  color: #555;
  display: block;
  font-size: 1.3rem;
  line-height: 1.6;
  padding: 15px 16px;
  position: relative;
  text-decoration: none; }

#menu .menulist .l2 a, #menu .menulist .l3 a {
  background-color: #fcfcfc; }

#rmenu .menulist .l2 a, #rmenu .menulist .l3 a {
  background-color: #fcfcfc; }

#menu .menulist .l2 a::before, #menu .menulist .l3 a::before {
  border-top: 1px solid #959595;
  box-sizing: border-box;
  content: '';
  height: 0;
  left: 20px;
  position: absolute;
  top: 23px;
  width: 8px; }

#rmenu .menulist .l2 a::before, #rmenu .menulist .l3 a::before {
  border-top: 1px solid #959595;
  box-sizing: border-box;
  content: '';
  height: 0;
  left: 20px;
  position: absolute;
  top: 23px;
  width: 8px; }

#menu .menulist .l2 a, #rmenu .menulist .l2 a {
  padding-left: 36px; }

#menu .menulist .l3 a, #rmenu .menulist .l3 a {
  padding-left: 52px; }

#menu .menulist .l3 a::before, #rmenu .menulist .l3 a::before {
  left: 36px; }

#menu :not(.menulist) > ul#submenu, #rmenu :not(.menulist) > ul#submenu {
  margin: 0;
  padding: 12px 12px 12px 30px; }

#menu :not(.menulist) > div#submenu, #rmenu :not(.menulist) > div#submenu {
  padding: 10px; }

#menu .rankbox, #rmenu .rankbox {
  margin: 0 0 10px; }

@media screen and (min-width: 768px) {
  #menu, #rmenu {
    margin-top: 0; }

  #menu h4, #menu .subtitle, #menu .title {
    padding: 2px; }

  #rmenu h4, #rmenu .subtitle, #rmenu .title {
    padding: 2px; }

  #menu h4 span, #menu .subtitle span, #menu .title span {
    border: 1px solid #fff;
    padding: 10px 13px; }

  #rmenu h4 span, #rmenu .subtitle span, #rmenu .title span {
    border: 1px solid #fff;
    padding: 10px 13px; }

  #menu .menubox, #menu .menubox2 {
    margin-bottom: 32px; }

  #rmenu .menubox, #rmenu .menubox2 {
    margin-bottom: 32px; }

  #menu :not(.menulist) > div#submenu, #rmenu :not(.menulist) > div#submenu {
    margin-top: 10px;
    padding: 0; } }
@media screen and (min-width: 1000px) {
  #menu .menulist li a, #rmenu .menulist li a {
    padding-right: 30px; }

  #menu .menulist li a::after, #rmenu .menulist li a::after {
    border-right: 2px solid #4887d9;
    border-top: 2px solid #4887d9;
    box-sizing: border-box;
    content: '';
    height: 9px;
    margin-top: -5px;
    opacity: 0;
    position: absolute;
    right: 21px;
    top: 50%;
    transform: rotate(45deg);
    transition: all 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
    width: 9px; }

  #menu .menulist li a:hover, #rmenu .menulist li a:hover {
    background-color: #fff;
    color: #4887d9;
    left: 0;
    opacity: 1;
    text-decoration: none !important;
    top: 0; }

  #menu .menulist li a:hover::after, #rmenu .menulist li a:hover::after {
    opacity: 1;
    right: 14px; }

  #menu :not(.menulist) > ul#submenu, #rmenu :not(.menulist) > ul#submenu {
    padding: 20px 20px 20px 38px; } }
/* バナー領域
==================================================
*/
.bannerbox {
  position: relative; }
  .bannerbox ul {
    list-style: outside none none;
    margin: 0;
    padding: 0; }
  .bannerbox li {
    margin-bottom: 10px;
    text-align: center; }
    .bannerbox li a img {
      vertical-align: bottom; }

/* 最新記事・アーカイブ
==================================================
*/
ul#newEntry, ul#entryarchive {
  list-style: outside none none;
  margin: 0;
  padding: 0; }
ul#newEntry li, ul#entryarchive li {
  border-bottom: 1px solid #ececec;
  font-size: 1.3rem;
  line-height: 1.6; }
ul#newEntry li a, ul#entryarchive li a {
  display: block;
  padding: 15px 16px; }
ul#newEntry li::after, ul#entryarchive li::after {
  clear: both;
  content: '';
  display: block; }

/*
==================================================
フッター
==================================================
*/
#footer {
  background-color: #222;
  color: #aaa;
  overflow: hidden;
  text-align: left; }
  #footer span > a > img {
    max-height: 240px; }
  #footer a {
    line-height: 1.6;
    margin: 0;
    padding: 0; }
  #footer .bottom_menu {
    /* フッター内のアイコン付きメニュー */
    background-color: #2d3033; }
    #footer .bottom_menu ul {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      list-style: outside none none;
      margin: 0;
      padding: 0; }
    #footer .bottom_menu li.bottom_menu_home a {
      display: block;
      margin: 0 20px;
      padding-left: 20px; }
      #footer .bottom_menu li.bottom_menu_home a::before {
        background-image: url(img/icon_home.png);
        height: 12px;
        opacity: 0.5;
        top: 3px;
        width: 10px; }
    #footer .bottom_menu li.bottom_menu_sitemap a {
      display: block;
      margin: 0 20px;
      padding-left: 23px; }
      #footer .bottom_menu li.bottom_menu_sitemap a::before {
        background-image: url(img/icon_sitemap.png);
        height: 11px;
        opacity: 0.5;
        top: 3px;
        width: 13px; }
    #footer .bottom_menu li.bottom_menu_sheare {
      border-bottom: 4px solid #383b3d;
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      order: -1;
      width: 100%; }
      #footer .bottom_menu li.bottom_menu_sheare a {
        display: block;
        height: 60px;
        overflow: hidden;
        text-indent: 200%;
        white-space: nowrap;
        width: 50px; }
        #footer .bottom_menu li.bottom_menu_sheare a::before {
          left: 50%;
          opacity: 0.4;
          top: 50%; }
        #footer .bottom_menu li.bottom_menu_sheare a.sheare_twitter::before {
          background-image: url(img/icon_twitter.png);
          height: 17px;
          margin: -8px 0 0 -11px;
          width: 21px; }
        #footer .bottom_menu li.bottom_menu_sheare a.sheare_facebook::before {
          background-image: url(img/icon_facebook.png);
          height: 20px;
          margin: -10px 0 0 -5px;
          width: 11px; }
        #footer .bottom_menu li.bottom_menu_sheare a.sheare_line::before {
          background-image: url(img/icon_line.png);
          height: 21px;
          margin: -10px 0 0 -11px;
          width: 22px; }
        #footer .bottom_menu li.bottom_menu_sheare a.sheare_rss::before {
          background-image: url(img/icon_rss.png);
          height: 17px;
          margin: -8px 0 0 -8px;
          width: 16px; }
        #footer .bottom_menu li.bottom_menu_sheare a.sheare_hatena::before {
          background-image: url(img/icon_hatena.png);
          height: 14px;
          margin: -7px 0 0 -10px;
          width: 19px; }
    #footer .bottom_menu li.bottom_menu_pagetop {
      margin-left: auto; }
      #footer .bottom_menu li.bottom_menu_pagetop a {
        background-color: #414449;
        display: block;
        height: 54px;
        overflow: hidden;
        position: relative;
        text-indent: 200%;
        white-space: nowrap;
        width: 54px; }
        #footer .bottom_menu li.bottom_menu_pagetop a::after {
          border-left: 1px solid #fff;
          border-top: 1px solid #fff;
          content: '';
          height: 10px;
          left: 50%;
          margin-left: -5px;
          margin-top: -2px;
          position: absolute;
          top: 50%;
          transform: rotate(45deg);
          width: 10px; }
    #footer .bottom_menu a {
      color: #fff;
      font-size: 1.3rem;
      position: relative;
      text-decoration: none; }
      #footer .bottom_menu a::before {
        background-position: left top;
        background-repeat: no-repeat;
        background-size: 100% auto;
        content: '';
        left: 0;
        position: absolute;
        transition: opacity .1s linear; }
  #footer .inner {
    padding: 26px 20px; }
  #footer #footermenu {
    text-align: left;
    padding: 0; }
  #footer span {
    display: block;
    line-height: 1; }
    #footer span a {
      color: #aaa;
      display: inline-block;
      font-size: 1.3rem;
      letter-spacing: 0;
      line-height: 1.6;
      margin: 0 0 25px;
      text-decoration: none; }
  #footer .space_footer {
    margin-bottom: 25px; }
  #footer .desc {
    font-size: 1.1rem;
    margin-bottom: 25px;
    text-align: left; }
  #footer small {
    display: block;
    font-size: 1.1rem;
    letter-spacing: 0.05em;
    line-height: 1.6;
    margin: 10px 0; }

@media screen and (min-width: 768px) {
  #footer #footermenu {
    margin-bottom: 25px; }
  #footer span {
    display: inline-block;
    margin: 10px 40px 10px 0; }
    #footer span a {
      margin: 0; }
  #footer .desc {
    font-size: 1.2rem; } }
@media screen and (min-width: 1000px) {
  #footer .bottom_menu {
    border-bottom: 4px solid #383b3d; }
    #footer .bottom_menu ul {
      margin: 0 auto; }
    #footer .bottom_menu li.bottom_menu_home a, #footer .bottom_menu li.bottom_menu_sitemap a {
      margin: 0 35px 0 0; }
    #footer .bottom_menu li.bottom_menu_sheare {
      border-bottom: none;
      margin-left: auto;
      order: 0;
      width: auto; }
    #footer .bottom_menu li.bottom_menu_pagetop {
      margin-left: 35px; }
      #footer .bottom_menu li.bottom_menu_pagetop a {
        height: 80px;
        width: 80px; }
        #footer .bottom_menu li.bottom_menu_pagetop a::after {
          border-left: 2px solid #fff;
          border-top: 2px solid #fff;
          height: 14px;
          margin-left: -8px;
          margin-top: -3px;
          transition: margin-top 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
          width: 14px; }
        #footer .bottom_menu li.bottom_menu_pagetop a:hover {
          background-color: #4d5156; }
          #footer .bottom_menu li.bottom_menu_pagetop a:hover::after {
            margin-top: -8px; }
    #footer .bottom_menu li a:hover {
      color: #fff;
      opacity: 1; }
      #footer .bottom_menu li a:hover::before {
        opacity: 1 !important; }
  #footer .inner {
    margin: 0 auto;
    padding: 50px 0;
    width: 1000px; }
  #footer #footermenubox {
    display: flex; }
  #footer #footermenu {
    margin-bottom: 50px;
    max-width: none !important;
    width: auto !important; }
  #footer span {
    margin-right: 90px; }
    #footer span a:hover {
      color: #fff;
      opacity: 1; }
  #footer .space_footer {
    flex-shrink: 0;
    margin-bottom: 50px; }
  #footer .desc {
    margin-bottom: 50px; } }
/*
==================================================
トップページ
==================================================
*/
#whatsnew {
  background-color: #f7f7f7;
  position: relative;
  text-align: left;
  width: 100%;
  z-index: 0;
  order: -1; }
  #whatsnew::before {
    background-image: url(img/line_bg.png);
    background-position: left top;
    background-repeat: repeat;
    background-size: 8px;
    bottom: 0;
    content: '';
    left: 0;
    opacity: 0.03;
    position: absolute;
    right: 0;
    top: 0;
    z-index: -1; }
  #whatsnew .title {
    color: #333;
    font-size: 2rem;
    font-weight: normal;
    letter-spacing: 0.05em;
    line-height: 1.4;
    padding: 20px 15px 8px; }
  #whatsnew ul {
    list-style: outside none none;
    margin: 0;
    padding: 0; }
    #whatsnew ul li {
      border-bottom: 1px solid #e3e3e3;
      box-sizing: border-box;
      font-size: 1.4rem;
      line-height: 1.5;
      padding: 10px 15px;
      text-align: left; }
      #whatsnew ul li:nth-child(even) {
        background: rgba(255, 255, 255, 0.35); }
    #whatsnew ul time, #whatsnew ul span {
      display: block; }
    #whatsnew ul a {
      color: #333; }

@media screen and (min-width: 768px) {
  #whatsnew {
    order: 0; } }
@media screen and (min-width: 1000px) {
  #whatsnew {
    padding: 54px 0; }
    #whatsnew .inner {
      box-sizing: border-box;
      margin: 0 auto;
      padding: 0 25px;
      width: 1000px; }
    #whatsnew .title {
      font-size: 2.4rem;
      padding: 0 0 20px; }
    #whatsnew ul li {
      display: flex;
      padding: 15px; }
    #whatsnew ul time {
      flex-shrink: 0;
      width: 12%; }
    #whatsnew ul a:hover {
      color: #4887d9;
      opacity: 1;
      text-decoration: underline; } }
@media screen and (min-width: 1000px) {
  #whatsnew .inner {
    max-width: 1000px;
    width: 1000px; } }
/*
==================================================
カテゴリーページ
==================================================
*/
#categorylist {
  text-align: left; }
  #categorylist .catbox {
    border-bottom: 1px solid #e4e4e4;
    margin-bottom: 20px; }
    #categorylist .catbox:last-of-type {
      margin-bottom: 0; }
  #categorylist .thumb {
    margin-bottom: 15px;
    text-align: center; }
    #categorylist .thumb img {
      height: 190px;
      width: 100%;
      object-fit: cover; }
  #categorylist .title {
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1.4;
    padding: 0 0 5px; }
    #categorylist .title a {
      color: #333;
      text-decoration: none; }
  #categorylist p {
    color: #858585;
    font-size: 1.2rem;
    line-height: 2;
    margin-bottom: 22px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2; }
  #categorylist .more a {
    background-color: #fff;
    border: 1px solid #2d3033;
    color: #2d3033;
    display: block;
    font-size: 1.3rem;
    height: 34px;
    line-height: 34px;
    margin: 0 auto 28px;
    text-align: center;
    text-decoration: none;
    width: 58%; }

#main #pagelist {
  margin: 15px 0;
  text-align: center; }
  #main #pagelist ul {
    letter-spacing: -.4em;
    list-style: outside none none;
    margin: 0;
    padding: 0; }
  #main #pagelist li {
    background-image: none;
    display: inline-block;
    letter-spacing: normal;
    margin: 0 6px 15px !important;
    padding: 0 !important; }
  #main #pagelist a {
    background-color: #414449;
    color: #fff;
    display: inline-block;
    font-size: 1.3rem;
    font-weight: normal;
    line-height: 1;
    margin: 0;
    padding: 12px 15px;
    text-align: center;
    text-decoration: none; }

@media screen and (min-width: 768px) {
  #categorylist {
    margin: 30px 0;
    padding: 0; }
    #categorylist .catbox {
      margin: 50px 0;
      padding: 0 0 50px; }
      #categorylist .catbox:last-of-type {
        margin-bottom: 50px; }
      #categorylist .catbox::after {
        clear: both;
        content: '';
        display: block; }
    #categorylist .thumb {
      margin-bottom: 0;
      margin-right: 30px;
      max-width: 300px;
      float: left;
      width: 40%; }
    #categorylist .body {
      overflow: hidden;
      padding-top: 5px; }
    #categorylist .title {
      font-size: 1.8rem;
      padding: 0 0 2.6%; }
    #categorylist p {
      font-size: 1.4rem;
      line-height: 1.9;
      margin-bottom: 8%;
      max-height: calc((1.4rem * 1.9) * 2); }
    #categorylist .more a {
      height: 40px;
      line-height: 40px;
      margin: 0 0 0 auto;
      width: 174px; }

  #main #pagelist {
    margin: 30px 0; }
    #main #pagelist li {
      margin: 0 8px 15px !important; }
    #main #pagelist a {
      font-size: 1.4rem;
      padding: 17px 20px; } }
@media screen and (min-width: 1000px) {
  #categorylist .title a:hover {
    color: #4887d9;
    left: 0;
    opacity: 1;
    top: 0;
    text-decoration: underline; }
  #categorylist .thumb a {
    display: block;
    transition: box-shadow 0.4s cubic-bezier(0.215, 0.61, 0.355, 1); }
    #categorylist .thumb a:hover {
      box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15);
      left: 0;
      opacity: 1;
      top: 0; }
  #categorylist .thumb img {
    font-family: 'object-fit: cover;'; }
  #categorylist .more a {
    overflow: hidden;
    position: relative;
    z-index: 0; }
    #categorylist .more a::before {
      background-color: #2d3033;
      bottom: 0;
      content: '';
      left: -10%;
      position: absolute;
      top: 0;
      transform: skewX(-30deg);
      transition: width 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
      width: 0;
      z-index: -1; }
    #categorylist .more a:hover {
      color: #fff;
      left: 0;
      opacity: 1;
      top: 0; }
      #categorylist .more a:hover::before {
        width: 120%; }

  #main #pagelist a {
    overflow: hidden;
    position: relative;
    z-index: 0; }
    #main #pagelist a::before {
      background-color: #4887d9;
      bottom: 0;
      content: '';
      left: -15%;
      position: absolute;
      top: 0;
      transition: width 0.2s cubic-bezier(0.215, 0.61, 0.355, 1);
      width: 0;
      z-index: -1;
      transform: skewX(-15deg); }
    #main #pagelist a:hover {
      left: 0;
      opacity: 1;
      top: 0; }
      #main #pagelist a:hover::before {
        width: 130%; } }
/*
==================================================
エントリーページ
==================================================
*/
#entry {
  width: 100%;
  order: -1; }

#entrylist {
  background-color: #f7f7f7;
  position: relative;
  text-align: left;
  width: 100%;
  z-index: 0; }
  #entrylist::before {
    background-image: url(img/line_bg.png);
    background-position: left top;
    background-repeat: repeat;
    background-size: 8px;
    bottom: 0;
    content: '';
    left: 0;
    opacity: 0.03;
    position: absolute;
    right: 0;
    top: 0;
    z-index: -1; }
  #entrylist h4 {
    border: none;
    color: #333;
    font-size: 2rem;
    font-weight: normal;
    letter-spacing: 0.05em;
    line-height: 1.4;
    margin: 0;
    padding: 20px 15px 15px; }
    #entrylist h4::before {
      display: none; }
  #entrylist dl {
    margin: 0;
    overflow: hidden;
    padding: 0 15px 10px; }
    #entrylist dl div {
      line-height: 1;
      margin: 5px 0; }
      #entrylist dl div::after {
        clear: both;
        content: '';
        display: block; }
  #entrylist .entry_thumb a {
    display: block;
    overflow: hidden;
    position: relative;
    width: 80px; }
    #entrylist .entry_thumb a img {
      height: 80px;
      width: 100%;
      object-fit: cover; }
  #entrylist dt .entry_title {
    display: block;
    margin-bottom: 7px;
    overflow: hidden;
    padding-top: 2px;
    text-overflow: ellipsis;
    white-space: nowrap; }
    #entrylist dt .entry_title a {
      color: #333;
      font-size: 1.3rem;
      font-weight: bold;
      line-height: 1.6;
      text-decoration: none; }
  #entrylist dd {
    color: #959595;
    font-size: 1.3rem;
    line-height: 1.6;
    margin: 0 0 24px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2; }

#relNavigate {
  display: flex;
  justify-content: space-between;
  letter-spacing: -1em;
  margin: 10px auto;
  padding: 0;
  text-align: left; }
  #relNavigate a {
    font-size: 1.3rem;
    letter-spacing: 0;
    line-height: 1.6;
    margin: 0;
    padding: 20px 0;
    text-decoration: none;
    width: 49%; }
    #relNavigate a:nth-child(2) {
      text-align: right; }

@media screen and (min-width: 768px) {
  #entry {
    order: 0; } }
@media screen and (min-width: 1000px) {
  #entrylist {
    padding: 54px 0; }
    #entrylist .inner {
      box-sizing: border-box;
      margin: 0 auto;
      padding: 0 25px;
      width: 1000px; }
    #entrylist h4 {
      font-size: 2.4rem;
      padding: 0 0 20px; }
    #entrylist dl {
      display: flex;
      flex-wrap: wrap;
      padding: 0; }
      #entrylist dl div {
        box-sizing: border-box;
        margin: 10px 5% 10px 0;
        width: 30%; }
        #entrylist dl div:nth-child(3n) {
          margin-right: 0; }
    #entrylist .entry_thumb {
      margin-right: 20px; }
      #entrylist .entry_thumb a {
        transition: box-shadow 0.4s cubic-bezier(0.215, 0.61, 0.355, 1); }
        #entrylist .entry_thumb a:hover {
          box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15);
          left: 0;
          opacity: 1;
          top: 0; }
        #entrylist .entry_thumb a img {
          font-family: "object-fit: cover;"; }
    #entrylist dt a:hover {
      color: #4887d9;
      left: 0 !important;
      opacity: 1;
      text-decoration: underline;
      top: 0 !important; }
    #entrylist dd {
      max-height: calc((1.3rem * 1.6) * 2); }

  #relNavigate {
    margin: 40px auto; }
    #relNavigate a {
      font-size: 1.4rem; }
      #relNavigate a:hover {
        left: 0;
        top: 0;
        text-decoration: underline; } }
@media screen and (min-width: 1000px) {
  #entrylist .inner {
    max-width: 1000px;
    width: 1000px; } }
/*
==================================================
サイトマップページ
==================================================
*/
#sitemaps {
  margin-bottom: 10px;
  overflow: hidden; }
  #sitemaps ul {
    list-style: outside none none;
    margin: 0;
    padding: 0; }
    #sitemaps ul li {
      line-height: 1;
      padding: 0; }
      #sitemaps ul li a {
        background-color: #fff;
        border-bottom: 1px solid #ececec;
        color: #555;
        display: block;
        font-size: 1.3rem;
        line-height: 1.6;
        padding: 15px 16px;
        position: relative;
        text-decoration: none; }
    #sitemaps ul .l2 a, #sitemaps ul .l3 a {
      background-color: #fcfcfc; }
    #sitemaps ul .l2 a::before, #sitemaps ul .l3 a::before {
      border-top: 1px solid #959595;
      box-sizing: border-box;
      content: '';
      height: 0;
      left: 20px;
      position: absolute;
      top: 23px;
      width: 8px; }
    #sitemaps ul .l2 a {
      padding-left: 36px; }
    #sitemaps ul .l3 a {
      padding-left: 52px; }
      #sitemaps ul .l3 a::before {
        left: 36px; }
  #sitemaps br {
    display: none; }

@media screen and (min-width: 768px) {
  #sitemaps {
    margin: 0 0 20px; }
    #sitemaps ul {
      padding: 0 10px; }
      #sitemaps ul li a {
        background-color: transparent;
        border: none;
        display: inline-block;
        font-size: 1.6rem;
        padding: 0; }
      #sitemaps ul .l1 {
        margin-top: 30px; }
      #sitemaps ul .l2, #sitemaps ul .l3 {
        margin-top: 15px; }
      #sitemaps ul .l2 a, #sitemaps ul .l3 a {
        background-color: transparent;
        font-size: 1.5rem; }
      #sitemaps ul .l2 a::before, #sitemaps ul .l3 a::before {
        top: 11px; } }
@media screen and (min-width: 1000px) {
  #sitemaps ul li a:hover {
    color: #4887d9;
    opacity: 1;
    text-decoration: underline; } }
/*
==================================================
フリースペース
==================================================
*/
#space3, #space4, #space5, #space6 {
  overflow: hidden;
  padding: 10px; }

@media screen and (min-width: 768px) {
  #space3, #space4, #space5, #space6 {
    margin-top: 10px;
    padding: 0; } }
/*
==================================================
ブログモード
==================================================
*/
.blog {
  background-color: #f7f7f7;
  margin: 0 0 30px;
  overflow: hidden;
  padding: 20px; }
  .blog a {
    text-decoration: none; }
  .blog .thumb {
    margin: -20px -20px 20px;
    overflow: hidden; }
    .blog .thumb img {
      height: 190px;
      width: 100%;
      object-fit: cover; }
  .blog .title {
    color: #444;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.6;
    margin-bottom: 10px; }
  .blog .body {
    color: #959595;
    font-size: 1.4rem;
    line-height: 1.9;
    margin-bottom: 24px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3; }
  .blog .info {
    border-top: 1px solid #e4e4e4;
    padding-top: 8px;
    text-align: right; }
  .blog time {
    background-image: url(img/icon_time.png);
    background-position: left 3px;
    background-repeat: no-repeat;
    background-size: 13px auto;
    color: #959595;
    display: inline-block;
    font-size: 1.1rem;
    margin-left: 16px;
    min-height: 13px;
    padding-left: 16px; }
  .blog .plist {
    float: left;
    text-align: left;
    max-width: 100%;
    display: inline-block;
    overflow: hidden;
    width: auto;
    padding: 3px 0 0; }
    .blog .plist a {
      background-image: url(img/icon_folder.png);
      background-position: left 3px;
      background-repeat: no-repeat;
      background-size: 14px auto;
      color: #959595;
      display: inline-block;
      font-size: 1.1rem;
      line-height: 1.6;
      min-height: 12px;
      padding-left: 20px;
      height: 20px;
      overflow: hidden;
      white-space: nowrap;
      text-overflow: ellipsis;
      text-align: left;
      margin: 3px 0;
      text-decoration: underline;
      max-width: 95%; }
      .blog .plist a:nth-last-child(2) {
        margin-right: 10px; }

@media screen and (min-width: 768px) {
  #bloglist {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }

  .blog {
    box-sizing: border-box;
    margin-bottom: 48px;
    width: 48%;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    justify-content: space-between; }
    .blog .title {
      font-size: 1.8rem;
      margin-bottom: 15px; }
    .blog .body {
      line-height: 2;
      margin-bottom: 28px;
      max-height: calc((1.4rem * 2) * 3); }
    .blog .info {
      padding-top: 12px; }
    .blog time, .blog .plist a {
      font-size: 1.2rem; } }
@media screen and (min-width: 1000px) {
  .blog {
    padding-left: 32px;
    padding-right: 32px; }
    .blog .thumb {
      margin-left: -32px;
      margin-right: -32px;
      position: relative; }
      .blog .thumb::before {
        background-color: rgba(0, 0, 0, 0.1);
        bottom: 0;
        content: '';
        left: 0;
        opacity: 0;
        position: absolute;
        right: 0;
        top: 0;
        transition: opacity 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
        z-index: 1; }
      .blog .thumb img {
        font-family: 'object-fit: cover;';
        transition: transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1); }
    .blog > a:hover {
      left: 0 !important;
      opacity: 1;
      top: 0 !important; }
      .blog > a:hover .title {
        color: #4887d9; }
      .blog > a:hover .thumb::before {
        opacity: 1; }
      .blog > a:hover .thumb img {
        transform: scale(1.1); } }
/*
==================================================
サイト内検索
==================================================
*/
#searchresult {
  margin-bottom: 10px; }
  #searchresult dl {
    margin: 0 0 -10px;
    overflow: hidden;
    padding: 0; }
  #searchresult dt {
    font-size: 1.4rem;
    line-height: 1.6;
    margin: 8px 0; }
  #searchresult dd {
    border-bottom: 1px solid #e4e4e4;
    color: #858585;
    font-size: 1.2rem;
    line-height: 1.6;
    margin: 0 0 10px;
    padding-bottom: 10px; }
  #searchresult b {
    color: #333; }

@media screen and (min-width: 768px) {
  #searchresult {
    margin-bottom: 20px; }
    #searchresult dl {
      mmargin: 0 0 -20px; }
    #searchresult dt {
      font-size: 1.6rem;
      margin: 10px 0; }
    #searchresult dd {
      font-size: 1.4rem;
      margin: 0 0 20px;
      padding-bottom: 20px; } }
/*
==================================================
リンク集
==================================================
*/
#linklist {
  margin: 0;
  overflow: hidden; }
  #linklist dt {
    font-size: 1.4rem;
    line-height: 1.6;
    margin: 8px 0; }
  #linklist dd {
    border-bottom: 1px solid #e4e4e4;
    color: #858585;
    font-size: 1.2rem;
    line-height: 1.6;
    margin: 0 0 10px;
    padding-bottom: 10px; }

@media screen and (min-width: 768px) {
  #linklist {
    margin-bottom: 20px; }
    #linklist dt {
      font-size: 1.6rem;
      margin: 10px 0; }
    #linklist dd {
      font-size: 1.4rem;
      margin: 0 0 20px;
      padding-bottom: 20px; } }
/*
==================================================
ポイント
==================================================
*/
/* メインコンテンツ用ポイント
==================================================
*/
div[class^="point"]:not(.point) {
  background-image: none;
  border: none;
  color: #333;
  font-size: 1.9rem;
  font-weight: bold;
  height: auto;
  line-height: 1.5;
  margin: 8px 0;
  min-height: 29px;
  padding: 1px 0 0px 40px;
  position: relative; }
  div[class^="point"]:not(.point)::before {
    background-position: left top;
    background-repeat: no-repeat;
    background-size: 100% auto;
    content: '';
    height: 29px;
    left: 0;
    position: absolute;
    top: 0;
    width: 29px; }

@media screen and (min-width: 1000px) {
  #column1 div[class^="point"]:not(.point), #main div[class^="point"]:not(.point) {
    font-size: 2.2rem;
    line-height: 1.4;
    margin: 15px 0;
    min-height: 36px;
    padding: 5px 0 0 50px; }

  #column1 div[class^="point"]:not(.point)::before, #main div[class^="point"]:not(.point)::before {
    height: 36px;
    width: 36px; } }
.point1::before {
  background-image: url(img/point1.png); }

.point2::before {
  background-image: url(img/point2.png); }

.point3::before {
  background-image: url(img/point3.png); }

.point4::before {
  background-image: url(img/point4.png); }

.point5::before {
  background-image: url(img/point5.png); }

.point6::before {
  background-image: url(img/point6.png); }

.point7::before {
  background-image: url(img/point7.png); }

.point8::before {
  background-image: url(img/point8.png); }

.point9::before {
  background-image: url(img/point9.png); }

.point10::before {
  background-image: url(img/point10.png); }

/* メニュー用ポイント
==================================================
*/
/*
==================================================
ランキング
==================================================
*/
/* メインコンテンツ用ランキング
==================================================
*/
.rank1, .rank2, .rank3, .rank4, .rank5, .rank6, .rank7, .rank8, .rank9, .rank10 {
  border: none;
  height: auto; }

.rank {
  background-color: #f1f1f1;
  background-image: linear-gradient(45deg, #f3f3f3 25%, #e5e5e5 25%, #e5e5e5 50%, #f3f3f3 50%, #f3f3f3 75%, #e5e5e5 75%, #e5e5e5);
  background-size: 5px 5px;
  margin: 0 0 20px;
  padding: 5px; }
  .rank .rank-container {
    background-color: #f7f7f7;
    background-image: linear-gradient(-45deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0.45) 100%);
    box-shadow: 0 3px 10px rgba(147, 147, 147, 0.15);
    overflow: hidden;
    padding: 15px; }
  .rank .rank-inner {
    border-bottom: 1px solid #e8e8e8;
    margin: 0 -15px 12px;
    padding: 3px 15px 18px; }
  .rank .rank1, .rank .rank2, .rank .rank3, .rank .rank4, .rank .rank5, .rank .rank6, .rank .rank7, .rank .rank8, .rank .rank9, .rank .rank10 {
    margin: 0;
    min-height: 37px;
    padding: 4px 0 4px 42px; }
  .rank .rank1::before, .rank .rank2::before, .rank .rank3::before, .rank .rank4::before, .rank .rank5::before, .rank .rank6::before, .rank .rank7::before, .rank .rank8::before, .rank .rank9::before, .rank .rank10::before {
    height: 37px;
    width: 36px; }
  .rank .rank1 a, .rank .rank2 a, .rank .rank3 a, .rank .rank4 a, .rank .rank5 a, .rank .rank6 a, .rank .rank7 a, .rank .rank8 a, .rank .rank9 a, .rank .rank10 a {
    color: #52555b;
    font-size: 2.2rem;
    line-height: 1.4;
    text-decoration: none; }
  .rank .float-l, .rank .float-r {
    box-sizing: border-box;
    float: none;
    margin: 0 auto 10px;
    max-width: 100%;
    text-align: center; }
  .rank .float-l img, .rank .float-r img {
    margin: 0 0 10px; }
  .rank .rankbox {
    margin: 10px 0; }
  .rank .feature {
    color: #595959;
    font-size: 1.8rem;
    line-height: 1.6;
    margin-bottom: 8px; }
  .rank .rank-table {
    /* 基本情報 テーブル */
    border-bottom: 1px solid #ececec;
    border-top: 1px solid #ececec;
    clear: both;
    margin: 20px 0; }
    .rank .rank-table table {
      border: none;
      border-spacing: 0px 1px;
      border-collapse: separate;
      font-size: 1.6rem;
      line-height: 1.6;
      margin: 0; }
      .rank .rank-table table th, .rank .rank-table table td {
        border: none;
        vertical-align: top; }
      .rank .rank-table table th {
        background-color: #f6f6f6;
        box-sizing: border-box;
        color: #333;
        font-weight: normal;
        letter-spacing: 0.1em;
        padding: 10px 6px;
        position: relative;
        text-align: center;
        width: 25%;
        z-index: 0; }
        .rank .rank-table table th::before {
          background-image: url(img/line_bg.png);
          background-position: left top;
          background-repeat: repeat;
          background-size: 8px;
          bottom: 0;
          content: '';
          left: 0;
          opacity: 0.05;
          position: absolute;
          right: 0;
          top: 0;
          z-index: -1; }
      .rank .rank-table table td {
        background-color: #fff;
        padding: 10px 12px; }
        .rank .rank-table table td span {
          display: inline-block;
          color: #a31647; }
          .rank .rank-table table td span b {
            font-family: Arial;
            font-size: 2.4rem;
            font-weight: normal;
            letter-spacing: 0;
            line-height: 1;
            margin-right: 3px; }
      .rank .rank-table table img {
        max-width: 107px;
        vertical-align: sub;
        width: 100%; }
  .rank .comment {
    /* 説明文2 総評 */
    background-color: #ececec;
    background-image: linear-gradient(45deg, #ececec 25%, #d9d9d9 25%, #d9d9d9 50%, #ececec 50%, #ececec 75%, #d9d9d9 75%, #d9d9d9);
    background-size: 5px 5px;
    clear: both;
    margin: 20px 0;
    padding: 4px; }
    .rank .comment .comment-inner {
      background-color: #fff;
      padding: 12px 16px; }
    .rank .comment .comment-tit {
      border-bottom: 1px solid #e8e8e8;
      margin-bottom: 12px;
      padding-bottom: 12px; }
      .rank .comment .comment-tit span {
        color: #595959;
        display: block;
        font-size: 1.8rem;
        line-height: 1.6; }
  .rank .more {
    clear: both;
    margin-top: 20px;
    position: relative;
    text-align: center; }
    .rank .more span {
      display: block;
      margin: 10px 0 5px;
      overflow: hidden;
      position: relative;
      z-index: 0; }
      .rank .more span::after {
        border: 1px solid rgba(255, 255, 255, 0.2);
        bottom: 2px;
        content: '';
        left: 2px;
        position: absolute;
        right: 2px;
        top: 2px;
        z-index: -1; }
      .rank .more span a {
        color: #fff;
        display: block;
        font-size: 1.8rem;
        font-weight: normal;
        line-height: 1.3;
        margin: 0;
        padding: 18px 48px 18px 20px;
        position: relative;
        text-decoration: none; }
        .rank .more span a::after {
          background-image: url(img/icon_arrow.png);
          background-position: left top;
          background-repeat: no-repeat;
          background-size: 100% auto;
          content: '';
          height: 14px;
          margin-top: -7px;
          position: absolute;
          right: 27px;
          top: 50%;
          width: 11px;
          z-index: -1; }
      .rank .more span.detail {
        /* ボタン 詳細ページはこちら */
        background-color: #424c6a; }
      .rank .more span.official {
        /* ボタン 公式ページはこちら */
        background-color: #b69e6a; }

.rank1, .rank2, .rank3, .rank4, .rank5, .rank6, .rank7, .rank8, .rank9, .rank10 {
  background-image: none;
  border: none;
  box-sizing: border-box;
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.5;
  margin: 12px 0;
  min-height: 25px;
  padding: 0 0 0 32px;
  position: relative; }

.rank1::before, .rank2::before, .rank3::before, .rank4::before, .rank5::before, .rank6::before, .rank7::before, .rank8::before, .rank9::before, .rank10::before {
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 100% auto;
  content: '';
  height: 25px;
  left: 0;
  position: absolute;
  top: 2px;
  width: 24px; }

.rank1::before {
  background-image: url(img/rank1.png); }

.rank2::before {
  background-image: url(img/rank2.png); }

.rank3::before {
  background-image: url(img/rank3.png); }

.rank4::before {
  background-image: url(img/rank4.png); }

.rank5::before {
  background-image: url(img/rank5.png); }

.rank6::before {
  background-image: url(img/rank6.png); }

.rank7::before {
  background-image: url(img/rank7.png); }

.rank8::before {
  background-image: url(img/rank8.png); }

.rank9::before {
  background-image: url(img/rank9.png); }

.rank10::before {
  background-image: url(img/rank10.png); }

@media screen and (min-width: 768px) {
  #column1 .rank, #main .rank {
    padding: 10px; }

  #column1 .rank .rank-container, #main .rank .rank-container {
    box-shadow: 0 3px 35px rgba(147, 147, 147, 0.15);
    padding: 35px; }

  #column1 .rank .rank-inner, #main .rank .rank-inner {
    margin: -8px -35px 40px;
    padding: 0 26px 26px; }

  #column1 .rank .rank1, #column1 .rank .rank2, #column1 .rank .rank3, #column1 .rank .rank4, #column1 .rank .rank5, #column1 .rank .rank6, #column1 .rank .rank7, #column1 .rank .rank8, #column1 .rank .rank9, #column1 .rank .rank10 {
    min-height: 58px;
    padding: 10px 0 0 72px; }

  #main .rank .rank1, #main .rank .rank2, #main .rank .rank3, #main .rank .rank4, #main .rank .rank5, #main .rank .rank6, #main .rank .rank7, #main .rank .rank8, #main .rank .rank9, #main .rank .rank10 {
    min-height: 58px;
    padding: 10px 0 0 72px; }

  #column1 .rank .rank1::before, #column1 .rank .rank2::before, #column1 .rank .rank3::before, #column1 .rank .rank4::before, #column1 .rank .rank5::before, #column1 .rank .rank6::before, #column1 .rank .rank7::before, #column1 .rank .rank8::before, #column1 .rank .rank9::before, #column1 .rank .rank10::before {
    height: 58px;
    width: 56px; }

  #main .rank .rank1::before, #main .rank .rank2::before, #main .rank .rank3::before, #main .rank .rank4::before, #main .rank .rank5::before, #main .rank .rank6::before, #main .rank .rank7::before, #main .rank .rank8::before, #main .rank .rank9::before, #main .rank .rank10::before {
    height: 58px;
    width: 56px; }

  #column1 .rank .rank1 a, #column1 .rank .rank2 a, #column1 .rank .rank3 a, #column1 .rank .rank4 a, #column1 .rank .rank5 a, #column1 .rank .rank6 a, #column1 .rank .rank7 a, #column1 .rank .rank8 a, #column1 .rank .rank9 a, #column1 .rank .rank10 a {
    font-size: 3rem; }

  #main .rank .rank1 a, #main .rank .rank2 a, #main .rank .rank3 a, #main .rank .rank4 a, #main .rank .rank5 a, #main .rank .rank6 a, #main .rank .rank7 a, #main .rank .rank8 a, #main .rank .rank9 a, #main .rank .rank10 a {
    font-size: 3rem; }

  #column1 .rank .rankbox, #main .rank .rankbox {
    margin: 20px 0;
    overflow: hidden; }

  #column1 .rank .feature, #main .rank .feature {
    font-size: 2rem;
    margin-bottom: 15px; }

  #column1 .rank .rank-table, #main .rank .rank-table {
    margin: 32px 0; }

  #column1 .rank .rank-table table th, #main .rank .rank-table table th {
    padding: 16px 8px;
    width: 18%; }

  #column1 .rank .rank-table table td, #main .rank .rank-table table td {
    padding: 16px 22px; }

  #column1 .rank .comment, #main .rank .comment {
    margin: 32px 0;
    padding: 6px; }

  #column1 .rank .comment .comment-inner, #main .rank .comment .comment-inner {
    padding: 24px; }

  #column1 .rank .comment .comment-tit, #main .rank .comment .comment-tit {
    margin: -2px 0 24px;
    padding: 0 5px 16px; }

  #column1 .rank .comment .comment-tit span, #main .rank .comment .comment-tit span {
    font-size: 2.2rem; }

  #column1 .rank .comment .comment-body, #main .rank .comment .comment-body {
    padding: 0 5px; }

  #column1 .rank .more span a, #main .rank .more span a {
    font-size: 2rem;
    letter-spacing: 0.05em;
    padding: 20px 28px 20px 15px; } }
@media screen and (min-width: 1000px) {
  .rank .rank1 a:hover, .rank .rank2 a:hover, .rank .rank3 a:hover, .rank .rank4 a:hover, .rank .rank5 a:hover, .rank .rank6 a:hover, .rank .rank7 a:hover, .rank .rank8 a:hover, .rank .rank9 a:hover, .rank .rank10 a:hover {
    color: #4887d9;
    opacity: 1; }
  .rank .more span a {
    transition: background-position .1s linear; }
    .rank .more span a::before {
      bottom: 0;
      content: '';
      left: -15%;
      position: absolute;
      top: 0;
      transform: skewX(-30deg);
      transition: width 0.33s cubic-bezier(0.215, 0.61, 0.355, 1);
      width: 0;
      z-index: -1; }
    .rank .more span a::after {
      transition: right .1s linear; }
    .rank .more span a:hover {
      left: 0 !important;
      opacity: 1;
      top: 0 !important; }
      .rank .more span a:hover::before {
        width: 130%; }
      .rank .more span a:hover::after {
        right: 23px; }
  .rank .more span.detail a::before {
    background-color: #263762; }
  .rank .more span.official a::before {
    background-color: #af8c36; } }
/* メニュー用ランキング
==================================================
*/
/* メニュー用 画像スタイルサイズ調整 */
/*
==================================================
２カラムレイアウト
==================================================
*/
@media screen and (min-width: 768px) {
  #column2 #main {
 /*   width: 72%; */
}
  #column2 #menu {
    padding: 25px 15px;
    width: 28%;
    order: -1;
    order: 0; } }
@media screen and (min-width: 1000px) {
  #column2 #main {
  /*  max-width: 720px; */
    width: calc(100% - 300px - 20px); }
    #column2 #main .rank .float-l, #column2 #main .rank .float-r {
      float: left;
      margin: 0 40px 10px 0;
      max-width: 40%; }
    #column2 #main .rank .float-l img, #column2 #main .rank .float-r img {
      margin: 0 0 20px; }
    #column2 #main .rank .more {
      display: flex;
      justify-content: space-between;
      margin: 35px -20px 0; }
      #column2 #main .rank .more span {
        flex-grow: 1;
        margin: 0 10px; }
  #column2 #menu {
    padding: 25px 0 0 0;
    width: 300px;
    margin-left: 20px; } }
/* スライダー用CSS */
#sl_header #header {
  background-color: #000 !important;
  overflow: hidden !important; }
  #sl_header #header span {
    width: 100% !important; }
#sl_header .slick-dots li button:before {
  background-color: white !important; }
#sl_header ul[id$="slider_ul"].slide_item a {
  text-decoration: none; }
#sl_header ul[id$="slider_ul"].slide_item .slidertitle {
  color: #FFF; }

@media screen and (min-width: 1000px) {
  #sl_header #topslider {
    max-width: 1000px;
    margin: 0 auto; } }
@media screen and (min-width: 1000px) {
  #sl_header #topslider {
    max-width: 1000px; } }
.sticky {
  z-index: 10; }

/*
==================================================
独自スタイル
==================================================
*/
.originbox01 {
  padding: 10px; }
  .originbox01 > div {
    margin: 5px 0;
    padding: 15px;
    box-sizing: border-box;
    background-color: #f5f5f5; }

@media screen and (min-width: 768px) {
  .originbox01 {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap; }
    .originbox01 div[class^="btn"] {
      width: auto; }
    .originbox01 > div {
      width: 49.5%; }
    .originbox01.col3 > div {
      width: 33%; }
    .originbox01.col4 > div {
      width: 24.5%; }
    .originbox01 > div:nth-last-child(2) {
      border-bottom: none; } }
/*
==================================================
レイアウト切り替え用スタイル
==================================================
*/
.freespace_sp {
  padding: 10px 0; }
  .freespace_sp:after {
    display: block;
    content: "";
    clear: both; }

#layoutbox::after {
  display: block;
  content: "";
  clear: both; }

#headerbox {
  height: auto !important; }

@media screen and (max-width: 767px) {
  #main, #menu, #rmenu, #layoutbox {
    float: none !important; } }
@media screen and (min-width: 768px) {
  #contents #main .txt-decbox1 .top {
    background-image: url("img/decbox_t.gif"), url("img/decbox_t.gif"), url("img/decbox_t.gif");
    background-position: left top, 850px top, 1700px top; }
  #contents #main .txt-decbox1 .bottom {
    background-image: url("img/decbox_b.gif"), url("img/decbox_b.gif"), url("img/decbox_b.gif");
    background-position: left top, 850px top, 1700px top; }

  .txt-decbox2 {
    position: relative;
    z-index: 0; }
    .txt-decbox2::before, .txt-decbox2::after {
      background-image: url("img/decbox2_r.gif");
      background-position: left bottom;
      background-repeat: repeat-y;
      bottom: 0;
      content: '';
      position: absolute;
      top: 0;
      width: 880px;
      z-index: -2; }
    .txt-decbox2::before {
      right: 900px; }
    .txt-decbox2::after {
      right: 1780px; }
    .txt-decbox2 .body {
      z-index: 1; }
    .txt-decbox2 .top, .txt-decbox2 .bottom {
      position: relative; }
    .txt-decbox2 .top::before, .txt-decbox2 .top::after {
      background-repeat: no-repeat;
      content: '';
      height: 16px;
      position: absolute;
      z-index: -1; }
    .txt-decbox2 .bottom::before, .txt-decbox2 .bottom::after {
      background-repeat: no-repeat;
      content: '';
      height: 16px;
      position: absolute;
      z-index: -1; }
    .txt-decbox2 .top::before, .txt-decbox2 .bottom::before {
      right: 900px; }
    .txt-decbox2 .top::before {
      background-image: url("img/decbox2_tr.gif");
      background-position: left top;
      top: 0;
      width: 890px; }
    .txt-decbox2 .top::after {
      background-image: url("img/decbox2_tr.gif");
      background-position: left top;
      top: 0;
      width: 890px;
      right: 1790px; }
    .txt-decbox2 .bottom::before {
      background-image: url("img/decbox2_br.gif");
      background-position: left bottom;
      bottom: 0;
      width: 730px; }
    .txt-decbox2 .bottom::after {
      background-image: url("img/decbox2_br.gif");
      background-position: left bottom;
      bottom: 0;
      width: 730px;
      right: 1630px; } }
@media screen and (min-width: 768px) {
  #main {
    float: left; }

  #column2 #menu {
    float: right; }

  #column3 #menu {
    float: right; }
  #column3 #rmenu {
    float: left; }
  #column3 #layoutbox {
    float: right; }
  #column3 #main {
    float: left; } }
/* 文字装飾
==================================================
*/
.fontStyle1 {
  font-weight: bold;
  background: -webkit-linear-gradient(transparent 85%, #ffff66 85%);
  background: linear-gradient(transparent 85%, #ffff66 85%); }

.fontStyle2 {
  background: -webkit-linear-gradient(transparent 85%, #ffff66 85%);
  background: linear-gradient(transparent 85%, #ffff66 85%); }

.fontStyle3 {
  font-weight: bold;
  background: -webkit-linear-gradient(transparent 95%, red 100%);
  background: linear-gradient(transparent 95%, red 100%); }

.fontStyle4 {
  background: -webkit-linear-gradient(transparent 85%, red 100%);
  background: linear-gradient(transparent 85%, red 100%); }

.fontStyle5 {
  font-weight: bold;
  color: #ff0000;
  background: -webkit-linear-gradient(transparent 90%, red 90%);
  background: linear-gradient(transparent 90%, red 90%); }

.fontStyle6 {
  color: #ff0000;
  background: -webkit-linear-gradient(transparent 95%, red 95%);
  background: linear-gradient(transparent 95%, red 95%); }

.fontStyle7 {
  color: #ff0000;
  background: -webkit-linear-gradient(transparent 80%, #ffff66 80%);
  background: linear-gradient(transparent 80%, #ffff66 80%); }

.fontStyle8 {
  color: #ff0000;
  font-weight: bold;
  background: -webkit-linear-gradient(transparent 80%, #ffff66 80%);
  background: linear-gradient(transparent 80%, #ffff66 80%); }

.fontStyle9 {
  font-weight: bold;
  color: #444444;
  border-bottom: 3px dotted #B9B9FF;
  padding: 0 .1em; }

.fontStyle10 {
  font-weight: bold;
  border-bottom: 2px dashed #00008C;
  color: #00008C;
  padding: 0 .1em; }


.table_recruit_detail_data {
	font-size:16px;
}


.site-signature{
  margin-top: 48px;
  padding-top: 10px;
  border-top: 1px solid #eee;
  font-size: 12px;
  color: #777;
  text-align: right;
  letter-spacing: 0.02em;
}
.site-signature a{
  color: #666;
  text-decoration: none;
}
.site-signature a:hover{
  text-decoration: underline;
}
