/*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */

/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Correct the line height in all browsers.
 * 3. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 */

/* Document
   ========================================================================== */

html {
  font-family: sans-serif; /* 1 */
  line-height: 1.15; /* 2 */
  -ms-text-size-adjust: 100%; /* 3 */
  -webkit-text-size-adjust: 100%; /* 3 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers (opinionated).
 */

body {
  margin: 0;
}

/**
 * Add the correct display in IE 9-.
 */

article,
aside,
footer,
header,
nav,
section {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

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

/* Grouping content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */

figcaption,
figure,
main { /* 1 */
  display: block;
}

/**
 * Add the correct margin in IE 8.
 */

figure {
  margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */

a {
  background-color: transparent; /* 1 */
  -webkit-text-decoration-skip: objects; /* 2 */
}

/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */

a:active,
a:hover {
  outline-width: 0;
}

/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

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

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */

b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font style in Android 4.3-.
 */

dfn {
  font-style: italic;
}

/**
 * Add the correct background and color in IE 9-.
 */

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

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */

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

/**
 * Remove the border on images inside links in IE 10-.
 */

img {
  border-style: none;
}

/**
 * Hide the overflow in IE.
 */

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

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
  text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */

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

/**
 * Remove the inner border and padding in Firefox.
 */

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

/**
 * Restore the focus styles unset by the previous rule.
 */

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

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */

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

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

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

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */

textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */

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

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

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

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */

details, /* 1 */
menu {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Scripting
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */

template {
  display: none;
}

/* Hidden
   ========================================================================== */

/**
 * Add the correct display in IE 10-.
 */

[hidden] {
  display: none;
}
@charset "UTF-8";

/* =====================
 * Settings
 * ===================== */
/* ===========================
 * General
 * =========================== */
/* ===========================
 * Components
 * =========================== */
/* ===========================
 * Layouts
 * =========================== */
/* ===========================
 * Typo
 * =========================== */
/* =====================
 * Base
 * ===================== */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  word-wrap: break-word;
}

input,
button,
select,
textarea,
optgroup {
  border: none;
  font-size: 14px;
  font-family: 游ゴシック, YuGothic, "Hiragino Kaku Gothic ProN", "Helvetica Neue", Helvetica, Arial, Meiryo, sans-serif;
}

ul {
  list-style: none;
}

img {
  vertical-align: bottom;
  width: auto;
  height: auto;
}

html,
body {
  font-size: 16px;
  line-height: 1;
  font-family: 游ゴシック, YuGothic, "Hiragino Kaku Gothic ProN", "Helvetica Neue", Helvetica, Arial, Meiryo, sans-serif;
  color: #555;
  background: #f9f9f9;
  height: 100%;
  word-break: break-word;
}

html,
body,
.container {
  min-width: 67.5rem;
}

.container {
  position: relative;
  height: auto;
  min-height: 100%;
}

body {
  font-size: 14px;
}

p {
  line-height: 1.7;
  white-space: pre-wrap;
}

a,
img,
input,
textarea,
button {
  transition: all 0.25s ease-out;
}

a {
  color: #f11a38;
  text-decoration: none;
  cursor: pointer;
}

a:hover {
  color: #f77a8c;
}

a > img:hover,
a > picture:hover {
  opacity: 0.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0 0 1rem;
}

h1 {
  font-size: 175%;
}

h2 {
  font-size: 150%;
}

h3 {
  font-size: 125%;
}

h4,
h5,
h6 {
  font-size: 100%;
}

@media screen and (max-width: 768px) {
  html,
  body,
  .container {
    min-width: 0;
    width: 100%;
  }
}

/* =====================
 * Components
 * ===================== */
/**
 *
 */
.img-cover {
  display: block;
  background-size: cover;
  background-position: center center;
  transition: all 0.25s ease-out;
}

.copyright {
  color: #aaa;
}

a:hover .img-cover {
  opacity: 0.5;
}

/**
 * Alert
 */
.alert {
  position: fixed;
  top: 0;
  width: 100%;
  padding: 1rem;
  background: rgba(119, 119, 119, 0.7);
  z-index: 20;
}

.alert.success {
  background: rgba(17, 162, 134, 0.7);
}

.alert.warning {
  background: rgba(253, 170, 27, 0.7);
}

.alert.danger {
  background: rgba(253, 116, 27, 0.7);
}

.alert.error {
  background: rgba(191, 21, 140, 0.7);
}

.alert-msg {
  width: 67.5rem;
  margin: 0 auto;
  text-align: center;
  color: #fff;
}

.form-alert {
  padding: 1rem;
  background: rgba(241, 26, 56, 0.2);
  color: #f11a38;
}

.form-alert .alert-item {
  padding-bottom: .5rem;
}

.form-alert .alert-item:last-child {
  padding-bottom: 0;
}

/**
 * AssetsImage
 */
.img-star-2x {
  height: 15px;
  width: auto;
}

.icon-seen {
  width: 18px;
  height: 15px;
  margin: 0.15rem auto 0;
  background-image: url("/images/seen_black@2x.png");
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
}

.icon-seen.white {
  background-image: url("/images/seen_white@2x.png");
}

.icon-want {
  width: 1rem;
  height: 1rem;
  margin: 0 auto;
  background-image: url("/images/want_black@2x.png");
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
}

.icon-want.white {
  background-image: url("/images/want_white@2x.png");
}

/**
 * Button
 */
.btn {
  display: inline-block;
  min-width: 10rem;
  margin: 0 1rem 1rem 0;
  padding: 0.75rem 0.5rem;
  border-radius: 2rem;
  font-size: 90%;
  line-height: 1rem;
  color: #fff;
  text-align: center;
  background: #f11a38;
}

.btn:hover {
  color: #fff;
  opacity: .5;
}

.btn.small {
  min-width: 5rem;
  padding: 0.5rem 0.5rem;
}

.btn.full {
  width: 100%;
}

.btn.secondary {
  background: #777;
}

.btn.secondary.hollow {
  border: 1px solid #777;
  color: #777;
  background: none;
}

.btn.success {
  background: #11a286;
}

.btn.success.hollow {
  border: 1px solid #11a286;
  color: #11a286;
  background: none;
}

.btn.warning {
  background: #fdaa1b;
}

.btn.warning.hollow {
  border: 1px solid #fdaa1b;
  color: #fdaa1b;
  background: none;
}

.btn.danger {
  background: #fd741b;
}

.btn.danger.hollow {
  border: 1px solid #fd741b;
  color: #fd741b;
  background: none;
}

.btn.hollow {
  border: 1px solid #f11a38;
  color: #f11a38;
  background: none;
}

.btn.no-margin-right {
  margin-right: 0;
}

.btn.no-margin {
  margin: 0;
}

.close {
  display: inline-block;
  position: absolute;
  top: .75rem;
  right: 1rem;
  width: 1.5rem;
  height: 1.5rem;
  background: none;
  text-indent: 100rem;
  white-space: nowrap;
  overflow: hidden;
}

.close.small {
  top: .5rem;
  right: .5rem;
  width: 1rem;
  height: 1rem;
}

.close.small::before, .close.small::after {
  left: 6px;
  width: 2px;
  height: 1rem;
}

.close:hover {
  opacity: .5;
}

.close::before, .close::after {
  display: block;
  position: absolute;
  top: 0;
  left: 10px;
  content: '';
  width: 3px;
  height: 1.5rem;
  transform: rotate(-45deg);
  background-color: #777;
  border-radius: 10px;
}

.close::after {
  transform: rotate(45deg);
}

/* ===========================
     * Share Button
     * =========================== */
.mobile .share-btns {
  font-size: 95%;
}

.share-btns {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  margin: 1rem 0;
  /* ===========================
         * Icon Font
         * =========================== */
}

.share-btns .share-btns__frame, .share-btns .share-btns__frame--fb, .share-btns .share-btns__frame--tw, .share-btns .share-btns__frame--hatena, .share-btns .share-btns__frame--line {
  -ms-flex: 1 0 auto;
      flex: 1 0 auto;
  min-width: auto;
  padding: .6rem 0;
  margin: 0 .4rem;
}

.share-btns__frame {
  background: #f11a38;
}

.share-btns__frame--fb {
  background: #3b5998;
}

.share-btns__frame--tw {
  background: #55acee;
}

.share-btns__frame--hatena {
  background: #00a4de;
}

.share-btns__frame--line {
  background: #05c402;
}

.share-btns .icon-twitter::before {
  content: "\ea96";
  font-size: 1rem;
}

.share-btns .icon-facebook::before {
  content: "\ea91";
  font-size: 1rem;
}

.share-btns .icon-line::before {
  content: "\e009";
  font-size: 1rem;
}

.share-btns .icon-hatena:before {
  content: "\e96a";
  font-size: 1rem;
}

/**
 * Form
 */
input, button, select, textarea {
  color: #555;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

input[disabled], button[disabled], select[disabled], textarea[disabled] {
  opacity: .5;
}

input {
  height: 2.25rem;
}

textarea {
  line-height: 1.7;
  resize: vertical;
}

textarea.no-resize {
  resize: none;
}

input, textarea, select {
  display: block;
  width: 100%;
  margin: 0 0 1rem;
  padding: 0.5rem;
  border: 1px solid #e3e3e3;
  border-radius: 3px;
  line-height: 1rem;
  background: #e3e3e3;
  outline: 0;
}

input:focus, textarea:focus, select:focus {
  background: white;
}

input.is-last, textarea.is-last, select.is-last {
  margin: 0;
}

input.short, textarea.short, select.short {
  max-width: 15rem;
}

input.medium, textarea.medium, select.medium {
  max-width: 25rem;
}

input:-moz-read-only {
  background: #aaa;
}

input:read-only {
  background: #aaa;
}

button {
  cursor: pointer;
}

label {
  display: inline-block;
  padding: .5rem 0;
  font-weight: bolder;
}

label.required::after {
  display: inline-block;
  content: '*';
  padding: 0 .5rem;
  color: #f11a38;
}

.input-wrap {
  margin: 0 0 1rem;
}

.input-wrap > input, .input-wrap textarea, .input-wrap select {
  margin: 0;
}

.input-wrap.is-last {
  margin: 0;
}

.select-wrap {
  position: relative;
}

.select-wrap::after {
  display: block;
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  content: "";
  width: 0;
  height: 0;
  border: inset 5px;
  border-color: #f11a38 transparent transparent;
  border-top-style: solid;
  border-bottom-width: 0;
}

.target-file-drop {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  min-height: 16rem;
  color: #555;
  font-size: 150%;
  font-weight: bold;
  background: #e3e3e3;
  transition: all .25s ease-out;
}

.form-container .form-row {
  display: -ms-flexbox;
  display: flex;
}

.form-container .form-row .form-col {
  padding: 1rem 0;
}

.form-container .form-row .form-col input, .form-container .form-row .form-col select, .form-container .form-row .form-col textarea {
  margin: 0;
}

.form-container .form-row .form-col:first-child {
  margin: 0 1rem 0 0;
  min-width: 10rem;
}

.form-container .form-row .form-col:first-child > label {
  display: inline-block;
  padding: 0.5rem 0;
  line-height: 1rem;
  font-weight: bolder;
}

.form-container .form-row .form-col:nth-child(2) {
  min-width: 20rem;
}

/**
 * FormCheckbox
 */
input[type="checkbox"] + .checkbox-icon {
  position: relative;
  vertical-align: middle;
}

input[type="checkbox"] + .checkbox-icon::before {
  font-family: "Font Awesome 5 Free";
  font-size: 1.5rem;
  content: "\f14a";
  color: white;
  text-shadow: 0 0 1px gray;
}

input[type="checkbox"]:checked + .checkbox-icon::before {
  font-family: "Font Awesome 5 Free";
  font-size: 1.5rem;
  content: "\f14a";
  color: black;
}

/**
 * Index
 */
.index-box {
  line-height: 0;
  background-color: #fff;
  /* The Modal (background) */
}

.index-box .index-wrapper {
  border: 1px solid #aaa;
}

.index-box .index-content {
  padding: 1.5rem 1.5rem 0;
}

.index-box .index-content .index-title {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.index-box .index-content .index-title .index-icon {
  position: relative;
  width: 18px;
  height: 15px;
  min-height: auto;
  margin-right: 0.4rem;
}

.index-box .index-content .index-title .index-title-text {
  font-size: 110%;
  color: #777;
  line-height: 1;
  white-space: nowrap;
}

.index-box .index-content ul {
  list-style-type: disc;
  display: block;
  position: relative;
  padding-left: 1rem;
}

.index-box .index-content ul[class="is-closed"] {
  max-height: 13rem;
  overflow: hidden;
  margin: 1rem 0 0.5rem;
}

.index-box .index-content ul[class="is-closed"]::after {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  content: "";
  width: 100%;
  height: 25%;
  background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0.7) 50%, #fff 88%);
}

.index-box .index-content ul[class="is-shown"] {
  margin: 1rem 0;
}

.index-box .index-content ul li {
  line-height: 1.5;
  margin-bottom: 0.5rem;
}

.index-box .index-content ul li a {
  color: #0d95b3;
}

.index-box .index-content ul li a:hover {
  color: #6ebfd1;
  text-decoration: underline;
}

.index-box .index-content ul li::marker {
  color: #777;
}

.index-box .index-content ul li.is-hidden {
  display: none;
}

.index-box .index-handler {
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
}

.index-box .index-handler input {
  width: initial;
  height: auto;
  border: initial;
  margin: initial;
}

.index-box .index-handler .index-handler-switch {
  display: inline-block;
  text-align: center;
  font-weight: 400;
  color: #777;
  padding: 1.5rem;
  width: 100%;
  cursor: pointer;
  transition: all 0.25s ease-out;
}

.index-box .index-handler .index-handler-switch::after {
  display: inline-block;
  position: absolute;
  content: "";
  top: 1.05rem;
  width: 5px;
  height: 5px;
  border: 2px solid;
  border-color: #565656 #565656 transparent transparent;
  margin-left: 0.3rem;
  transform: rotate(135deg);
}

.index-box .index-handler .index-handler-switch:hover {
  background-color: #f9f9f9;
}

.index-box .index-handler .index-handler-checkbox:checked + .index-handler-switch::after {
  top: 1.35rem;
  transform: rotate(315deg);
}

.index-box .index-fixed-wrapper button.index-fixed-button {
  position: fixed;
  bottom: 200px;
  right: -1px;
  z-index: 10;
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid #12d5ff;
  border-radius: 8px 0 0 8px;
  box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.15);
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  line-height: 1;
}

.index-box .index-fixed-wrapper button.index-fixed-button:hover {
  text-decoration: none;
}

.index-box .index-fixed-wrapper button.index-fixed-button .index-fixed-icon {
  width: 18px;
  height: 15px;
  min-height: auto;
  margin: 0 auto;
}

.index-box .index-fixed-wrapper button.index-fixed-button .index-fixed-label {
  font-size: 10px;
  margin-top: 2px;
}

.index-box .index-fixed-wrapper a {
  color: #555;
}

.index-box .index-fixed-wrapper a:hover {
  color: #888888;
  text-decoration: underline;
}

.index-box .index-modal {
  display: none;
  /* Case of close 'none', Case of open 'flex'. */
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: center;
      justify-content: center;
  position: fixed;
  line-height: 1;
  background-color: rgba(0, 0, 0, 0.7);
  /* Black w/ opacity */
  z-index: 100;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  /* Modal Content */
}

.index-box .index-modal .index-modal-content-wrapper {
  background-color: #fff;
  margin: 1rem 1rem 256px;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  height: 100%;
  max-height: calc(100vh - 1rem - 256px);
  padding: 1.5rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__head {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
  line-height: 0;
  color: #777;
  padding-bottom: 1rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__head .title {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__head .title__icon {
  width: 18px;
  height: 15px;
  min-height: auto;
  margin-right: 0.4rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__head .title__text {
  font-size: 110%;
  line-height: 0;
  white-space: nowrap;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__head .close-button {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  font-size: 1.8rem;
  font-weight: bold;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__main {
  line-height: 1.5;
  overflow-y: scroll;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__main a {
  color: #0d95b3;
  cursor: pointer;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .index-accordion-head {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: start;
      align-items: flex-start;
  font-weight: bold;
  padding: 0.3rem 0;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .index-accordion-head a {
  margin-left: 0.8rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .index-accordion-head__switch {
  display: inline-block;
  background-color: #fff;
  border: solid #777;
  border-width: 0 0.13rem 0.13rem 0;
  padding: 0.3rem;
  margin: 0.26rem 0.1rem 0.1rem;
  transform: rotate(-45deg);
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .index-accordion-panel {
  padding: 0 18px;
  background-color: white;
  overflow: hidden;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .index-accordion-active {
  margin: 0.1rem;
  transform: rotate(45deg);
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .disc-list {
  list-style: disc;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .circle-list {
  list-style: circle;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .one-level-indent {
  padding-left: 1rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .two-level-indent {
  padding-left: 2rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .lowest-list-item {
  padding: 0.2rem 0;
  font-size: 14px;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .lowest-list-item::marker {
  color: #777;
}

@media screen and (max-width: 768px) {
  .index-box .index-content {
    padding: 1rem 1rem 0;
  }
  .index-box .index-content ul[class="is-shown"] {
    margin: 1rem 0;
  }
  .index-box .index-handler .index-handler-switch {
    padding: 1rem;
  }
  .index-box .index-handler .index-handler-switch::after {
    top: 0.5rem;
  }
  .index-box .index-handler .index-handler-switch:hover {
    background-color: inherit;
  }
  .index-box .index-handler .index-handler-checkbox:checked + .index-handler-switch:after {
    top: 0.9rem;
  }
}

/**
 * Inducdtions
 */
/* ===========================
     * Induction App
     * =========================== */
.media-app-induction.is-hidden {
  display: none;
}

/**
 * BreadCrumb
 */
.breadcrumb {
  width: 100%;
  padding: 1rem 0;
  overflow: auto;
  white-space: nowrap;
}

.breadcrumb ol {
  width: 67.5rem;
  margin: 0 auto;
}

.breadcrumb ol li {
  display: inline-block;
  position: relative;
  padding: 0.25rem;
  padding-right: 0.5rem;
  font-size: 90%;
}

.breadcrumb ol li a {
  color: #0d95b3;
}

.breadcrumb ol li a:hover {
  color: #6ebfd1;
  text-decoration: underline;
}

.breadcrumb ol li a {
  display: inline-block;
  padding: .25rem;
}

.breadcrumb ol li strong {
  display: inline-block;
  padding: .25rem;
  font-weight: normal;
}

.breadcrumb ol li::after {
  display: inline-block;
  position: absolute;
  top: .6rem;
  right: 0;
  content: '';
  width: .375rem;
  height: .375rem;
  border-top: 1px solid #777;
  border-right: 1px solid #777;
  transform: rotate(45deg);
}

.breadcrumb ol li:last-child {
  padding-right: 0.25rem;
}

.breadcrumb ol li:last-child::after {
  display: none;
}

@media screen and (max-width: 768px) {
  .breadcrumb {
    padding: 0 .5rem;
    background-color: #fff;
    border-bottom: 1px solid #eee;
  }
  .breadcrumb ol {
    width: 100%;
  }
}

/**
 * Pagination
 */
.pagination {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.pagination .pagination-item:last-child {
  margin-right: 0;
}

.pagination-item {
  display: inline-block;
  margin-right: 1rem;
  margin-bottom: 1rem;
  padding: .5rem;
  font-size: 125%;
  font-weight: bolder;
}

.pagination-item.current {
  color: #555;
}

.pagination-item.ellipsis {
  color: #aaa;
  padding: .5rem .25rem;
}

a.pagination-item {
  color: #aaa;
  border-bottom: 2px solid #aaa;
}

a.pagination-item:hover {
  color: #f11a38;
  border-bottom: 2px solid #f11a38;
}

/**
 * Link
 */
.aside-link {
  font-size: 90%;
  text-decoration: underline;
  text-align: right;
}

.aside-link a {
  color: #717171;
}

/**
 * Ad
 */
.ad-frame {
  border-width: 1px 0;
  border-style: dashed;
  border-color: #aaa;
}

.ad-box {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  line-height: 0;
}

.ad-box.double {
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.ad-label {
  color: #aaa;
  font-weight: bold;
  transform: translateY(-6px);
  text-align: center;
  font-size: 12px !important;
  margin: auto;
  width: 32px;
  background: #fff;
  line-height: unset !important;
}

.billboard-ad-frame-wrapper {
  padding: 1rem 0;
}

.header-ad-frame-wrapper {
  padding: 1rem;
}

.middle-ad-box {
  padding-bottom: 24px;
}

.billboard-ad-box,
.header-ad-box,
.footer-ad-box,
.infeed-ad-box {
  padding-bottom: 32px !important;
}

.middle-ad-label {
  padding-bottom: 12px;
}

.billboard-ad-label,
.header-ad-label,
.footer-ad-label,
.infeed-ad-label {
  padding-bottom: 20px;
}

/**
 * Ad (site takeover)
 */
.gate-billboard {
  width: 67.5rem;
  margin: auto;
}

.gate-billboard img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@media screen and (max-width: 768px) {
  .gate-billboard.desktop {
    display: none;
  }
  .gate-billboard.mobile {
    width: 100%;
  }
}

.gate-skyscraper {
  position: fixed;
  width: calc((100vw - 67.5rem) / 2);
  height: calc(100vh - 3rem);
  bottom: 0;
}

.gate-skyscraper.has-header-takeover {
  height: calc(100vh - 4rem);
}

.gate-skyscraper.left {
  left: 0;
}

.gate-skyscraper.right {
  right: 0;
}

.gate-skyscraper.solid {
  display: -ms-flexbox;
  display: flex;
}

.gate-skyscraper.solid.left {
  -ms-flex-pack: right;
      justify-content: right;
}

.gate-skyscraper.solid.right {
  -ms-flex-pack: left;
      justify-content: left;
}

.gate-skyscraper.solid img {
  height: 700px;
  -o-object-fit: contain;
     object-fit: contain;
}

.gate-skyscraper.liquid.left img {
  -o-object-position: right top;
     object-position: right top;
}

.gate-skyscraper.liquid.right img {
  -o-object-position: left top;
     object-position: left top;
}

.gate-skyscraper.liquid img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@media screen and (max-width: 1279px) {
  .gate-skyscraper {
    display: none;
  }
}

@media screen and (min-width: 1536px) {
  .gate-skyscraper.liquid {
    display: -ms-flexbox;
    display: flex;
  }
  .gate-skyscraper.liquid.left {
    -ms-flex-pack: right;
        justify-content: right;
  }
  .gate-skyscraper.liquid.right {
    -ms-flex-pack: left;
        justify-content: left;
  }
  .gate-skyscraper.liquid img {
    width: 160px;
    height: 700px;
    -o-object-fit: contain;
       object-fit: contain;
  }
}

.sp-gate-anchor {
  background-color: lightgray;
  position: fixed;
  bottom: 0px;
  z-index: 2147483647;
  left: 0;
  width: 100vw;
}

.sp-gate-anchor__close-button {
  display: block;
  width: 27px;
  height: 27px;
  position: absolute;
  right: 0px;
  top: -27px;
  font-size: 27px;
  text-align: center;
  color: #aaa;
  font-weight: bold;
  background-color: #eee;
  border-radius: 12px 0 0 0;
}

.sp-gate-anchor__image {
  width: 100%;
  height: auto;
  max-height: 160px;
  -o-object-fit: contain;
     object-fit: contain;
}

/**
 * head
 */
.head-main {
  font-size: 1.1rem;
  line-height: 1.5;
  padding: 0 0 .5rem;
  border-bottom: 1px solid #555;
}

.head-sub {
  position: relative;
  padding-left: 2rem;
  font-size: 1rem;
}

.head-sub::before {
  display: block;
  position: absolute;
  top: .25rem;
  left: .5rem;
  content: '';
  width: .5rem;
  height: .5rem;
  background: #555;
}

@media screen and (max-width: 768px) {
  .head-main {
    font-size: 1.045rem;
  }
  .head-sub {
    font-size: 0.95rem;
  }
}

/**
 * Ranking
 */
.list-ranking {
  position: relative;
}

.list-ranking .item-ranking::before {
  display: block;
  position: absolute;
  width: 20px;
  height: 20px;
  color: #fff;
  text-align: center;
  background: #f11a38;
  line-height: 20px;
}

.list-ranking .item-ranking:nth-of-type(1)::before {
  content: "1";
  z-index: 2;
}

.list-ranking .item-ranking:nth-of-type(2)::before {
  content: "2";
  z-index: 2;
}

.list-ranking .item-ranking:nth-of-type(3)::before {
  content: "3";
  z-index: 2;
}

.list-ranking .item-ranking:nth-of-type(4)::before {
  content: "4";
  z-index: 2;
}

.list-ranking .item-ranking:nth-of-type(5)::before {
  content: "5";
  z-index: 2;
}

.list-ranking .item-ranking:nth-of-type(1)::before {
  background: #ffd700;
}

.list-ranking .item-ranking:nth-of-type(2)::before {
  background: #c0c0c0;
}

.list-ranking .item-ranking:nth-of-type(3)::before {
  background: #d2691e;
}

/**
 * ArticleItem
 */
.article-item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  padding: 0 1rem 1rem;
}

.article-item:hover {
  opacity: 0.7;
}

.article-item-link {
  color: #555;
  background: #fff;
}

.article-item-thumbnail {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 80px;
  margin-right: 1rem;
  overflow: hidden;
}

.article-item-thumbnail .img-cover {
  width: 5rem;
  height: 5rem;
}

.article-item-thumbnail .img-cover img {
  width: 100%;
  height: 100%;
}

.article-item-text {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.article-item-text .article-item-title {
  line-height: 1.4;
  margin-bottom: 0.5rem;
  overflow: hidden;
}

.article-item-text .article-item-heading {
  color: #555;
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.4;
  display: -webkit-box;
  /*! autoprefixer: off */
  -webkit-box-orient: vertical;
  /*! autoprefixer: on */
  -webkit-line-clamp: 2;
}

.article-item-text .article-item-heading:hover {
  text-decoration: underline;
}

.article-item-text .article-item-info {
  position: absolute;
  right: 0;
  bottom: 0;
  color: #aaa;
  font-size: 90%;
}

.article-item-text .article-item-info span {
  display: inline-block;
  margin-top: 0.5rem;
  margin-right: 0.5rem;
}

.article-item-text .article-item-desc {
  color: #aaa;
  margin-top: 0.2rem;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.article-list.no-side .article-item {
  padding: 0 0 1rem;
}

.article-list li.ranking > a::before {
  display: block;
  position: absolute;
  width: 20px;
  height: 20px;
  color: #fff;
  text-align: center;
  background: #f11a38;
  line-height: 20px;
}

.article-list li.ranking:nth-of-type(1) > a::before {
  content: "1";
  z-index: 2;
}

.article-list li.ranking:nth-of-type(2) > a::before {
  content: "2";
  z-index: 2;
}

.article-list li.ranking:nth-of-type(3) > a::before {
  content: "3";
  z-index: 2;
}

.article-list li.ranking:nth-of-type(4) > a::before {
  content: "4";
  z-index: 2;
}

.article-list li.ranking:nth-of-type(5) > a::before {
  content: "5";
  z-index: 2;
}

.article-list li.ranking:nth-of-type(1) > a::before {
  background: #ffd700;
}

.article-list li.ranking:nth-of-type(2) > a::before {
  background: #c0c0c0;
}

.article-list li.ranking:nth-of-type(3) > a::before {
  background: #d2691e;
}

.related-article-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
      grid-template-columns: 1fr 1fr;
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
}

.related-article-item {
  -ms-flex-align: center;
      align-items: center;
  display: -ms-flexbox;
  display: flex;
}

.related-article-item:hover {
  opacity: 0.7;
}

.related-article-item-thumbnail {
  color: #555;
  background: #fff;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  overflow: hidden;
  margin-right: 1rem;
  width: 5rem;
  height: 5rem;
  display: block;
}

.related-article-item-thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.related-article-item-thumbnail img:hover {
  opacity: 0.5;
}

.related-article-item-text {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.related-article-item-text__link {
  color: #555;
  background: #fff;
}

.related-article-item-text__link h4 {
  line-height: 1.4;
  margin-bottom: 0.5rem;
  overflow: hidden;
  color: #555;
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.4;
  display: -webkit-box;
  /*! autoprefixer: off */
  -webkit-box-orient: vertical;
  /*! autoprefixer: on */
  -webkit-line-clamp: 2;
}

.related-article-item-text__link h4:hover {
  text-decoration: underline;
}

.related-article-item-text__label {
  position: absolute;
  right: 0;
  bottom: 0;
  color: #aaa;
  font-size: 90%;
}

.related-article-item-text__label span {
  display: inline-block;
  margin-top: 0.5rem;
  margin-right: 0.5rem;
}

.label-pr {
  display: inline-block;
  padding: 0.1rem 0.15rem;
  border: 1px solid #aaa;
  border-radius: 3px;
  line-height: 1;
  font-size: 0.7rem;
  color: #aaa;
}

.faq-item {
  margin-bottom: 0.5rem;
  border: 1px solid #555;
  border-radius: 3px;
}

.faq-item .faq-icon {
  height: 24px;
  width: 24px;
  text-align: center;
  line-height: 24px;
  color: #f11a38;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.faq-item .faq-item-question {
  margin: 8px;
  padding: 0px;
  line-height: 1.5;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: start;
      align-items: flex-start;
  cursor: pointer;
}

.faq-item .faq-item-question:hover {
  opacity: 0.5;
}

.faq-item .faq-item-question h3 {
  font-size: 1rem;
  white-space: pre-wrap;
  word-break: break-all;
  margin: 0px 8px 0px 0px;
}

.faq-item .faq-item-question .faq-question-icon {
  font-size: 18px;
  font-weight: normal;
  margin-right: 8px;
}

.faq-item .faq-item-question .faq-toggle-plus-icon {
  font-size: 1.5rem;
  font-weight: lighter;
  display: block;
  margin-left: auto;
}

.faq-item .faq-item-question .faq-toggle-minus-icon {
  font-size: 1.2rem;
  font-weight: lighter;
  display: none;
  margin-left: auto;
}

.faq-item .faq-item-answer {
  overflow: hidden;
  transition: all 0.25s;
  height: 0;
  margin: 0px 8px;
}

.faq-item .faq-item-answer p {
  font-size: 110%;
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-all;
}

.faq-item .faq-item-answer strong {
  font-weight: bolder;
}

.faq-item .faq-item-answer em.highlight {
  background: linear-gradient(transparent 60%, #ffdfef 0%);
  line-height: 25px;
  font-size: 16px;
  font-weight: bolder;
  font-style: normal;
}

.faq-item .faq-item-answer a:not([class]) {
  text-decoration: underline;
  color: #0d95b3;
}

.faq-item .faq-item-answer a:not([class]):focus {
  outline: 0;
}

.faq-item .faq-item-answer a:not([class]):hover {
  opacity: 0.5;
}

.faq-item .faq-item-answer .faq-answer-icon {
  font-size: 18px;
  margin-right: 8px;
  -ms-flex-item-align: start;
      -ms-grid-row-align: start;
      align-self: start;
}

.faq-item .faq-handler-checkbox {
  display: none;
}

.faq-item .faq-handler-checkbox:checked + .faq-item-question + .faq-item-answer {
  height: auto;
  margin: 8px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: start;
      align-items: flex-start;
}

.faq-item .faq-handler-checkbox:checked + .faq-item-question .faq-toggle-plus-icon {
  display: none;
}

.faq-item .faq-handler-checkbox:checked + .faq-item-question .faq-toggle-minus-icon {
  display: block;
}

@media screen and (max-width: 768px) {
  .article-item .article-item-heading {
    overflow: hidden;
    white-space: normal;
    -webkit-line-clamp: 3;
  }
  .article-item .article-item-desc {
    display: none;
  }
  .related-article-item {
    display: block;
  }
  .related-article-item-thumbnail {
    margin-right: 0;
    width: 100%;
    height: 100%;
  }
  .related-article-item-thumbnail img {
    -o-object-fit: cover;
       object-fit: cover;
    aspect-ratio: 23/12;
  }
  .related-article-item-text__link h4 {
    margin-bottom: 0;
    margin-top: 0.25rem;
    font-size: 0.75rem;
  }
}

/**
 * Feature
 */
/**
     * FeatureList
     */
.feature-list {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
}

.feature-list li:last-child {
  margin-bottom: .4rem;
}

/**
     * FeatureItem
     */
.feature-item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  margin: .4rem 0;
  transition: all .25s ease-out;
}

.feature-item:hover {
  opacity: .5;
  color: #fff;
}

.feature-item .feature-image {
  display: block;
  height: 5rem;
  min-width: 5rem;
  background-color: #555;
  background-position: center center;
  background-size: cover;
  border-radius: 50%;
  margin-right: 1rem;
}

.feature-item .feature-image img {
  min-width: 100%;
  height: 100%;
  border-radius: 50%;
}

.feature-item .feature-item-name {
  display: block;
  color: #555;
  line-height: 1.4;
  margin: .3rem 0 .4rem;
}

.feature-item .feature-item-name:hover {
  text-decoration: underline #555;
}

.feature-item .feature-item-desc {
  font-size: .8rem;
  color: #717171;
  background: #fff;
}

/**
     * FeatureGrid
     */
.feature-grid {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding-left: 1rem;
}

.feature-grid > * {
  width: 50%;
  padding: 0 1rem 1rem 0;
}

@media screen and (max-width: 768px) {
  .feature-grid > * {
    width: 100%;
  }
  .feature-grid .feature-item-large {
    border-bottom: 1px solid #eee;
  }
}

/**
 * Review
 */
.review-list .review-item {
  background: #f9f9f9;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 1rem;
  padding: 1rem 1rem 0.5rem;
}

.review-list .review-list-item:last-child .review-item {
  margin-bottom: 0;
}

.review-list .review-user {
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}

.review-list .review-user-thumb {
  margin-right: 1rem;
}

.review-list .review-item-cap {
  margin-bottom: 0.5rem;
}

.review-list .review-item-cap > * {
  display: inline-block;
  margin-right: 0.5rem;
  line-height: 0.75rem;
}

.review-list .review-item-cap span:last-of-type {
  margin-right: 0;
}

.review-list .username {
  font-weight: bolder;
}

.review-list .img-star-2x {
  height: 14px;
  width: auto;
}

.review-list .date {
  color: #aaa;
  font-size: 90%;
}

.review-list .review-item-content {
  font-size: 90%;
}

.review-list .review-item-content .content {
  display: block;
  width: 100%;
}

/**
 * Search
 */
.search-nav-menu .nav-menu {
  padding: 0 1rem;
}

.search-nav-menu .nav-menu .nav-menu-content {
  display: -ms-flexbox;
  display: flex;
}

.search-nav-menu .nav-menu .nav-menu-content .nav-menu-item {
  -ms-flex: 1;
      flex: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.search-nav-menu .nav-menu .nav-menu-content .nav-menu-item a {
  color: #555;
}

.search-nav-menu .nav-menu .nav-menu-content .nav-menu-item a:hover {
  color: #888888;
  text-decoration: underline;
}

.search-nav-menu .nav-menu .nav-menu-content .nav-menu-item a {
  display: block;
  padding: .5rem 0;
  background: #f9f9f9;
}

.search-nav-menu .nav-menu .nav-menu-content .nav-menu-item .nav-menu-item-content {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-direction: column;
      flex-direction: column;
  height: 2rem;
  font-size: .8rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.25;
  border-right: 1px solid #e3e3e3;
}

.search-nav-menu .nav-menu .nav-menu-content .nav-menu-item:last-child .nav-menu-item-content {
  border-right: none;
}

.search-nav-menu .nav-menu .nav-menu-content .nav-menu-item.is-active a {
  color: #aaa;
}

.input-search-unit {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  height: 5rem;
}

.input-search-unit input {
  transition-property: initial;
}

.input-search-unit .input-search-bar {
  width: 15rem;
  height: 2.7rem;
  padding-left: 1.3rem;
  border-radius: 1.2rem 0 0 1.2rem;
  border: 0;
  font-size: 12px;
  background-color: #fff;
  margin: 0;
  filter: drop-shadow(2px 2px 2px rgba(0, 0, 0, 0.6));
}

.input-search-unit .input-search-btn {
  width: 4rem;
  height: 2.7rem;
  border-radius: 0 1.2rem 1.2rem 0;
  border: 0;
  font-size: .78rem;
  font-weight: bold;
  color: #fff;
  background-color: #f11a38;
  margin: 0;
  filter: drop-shadow(1px 2px 2px rgba(0, 0, 0, 0.6));
}

.input-search-unit .input-search-btn:hover {
  opacity: .7;
}

.input-search-unit .input-search-btn:active {
  opacity: .5;
}

.search .main-unit {
  padding: 2rem 1rem 0;
}

.search .input-search-unit {
  background-color: #f9f9f9;
}

/**
     * Mobile Layout
     */
@media screen and (max-width: 768px) {
  .input-search-unit .input-search-bar {
    height: 2.2rem;
    -webkit-appearance: none;
    border-radius: 1rem 0 0 1rem;
  }
  .input-search-unit .input-search-btn {
    height: 2.2rem;
    border-radius: 0 1rem 1rem 0;
  }
}

/**
 * CategoryItem
 */
.cat-item-wrap {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  border-top: 1px solid #555;
  border-left: 1px solid #555;
}

.cat-item-wrap > * {
  width: 50%;
  border-right: 1px solid #555;
  border-bottom: 1px solid #555;
}

.cat-item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  height: 3.5rem;
  color: #555;
  background-position: center center;
  background-size: cover;
}

.cat-item .cat-item-name {
  font-weight: bolder;
}

.cat-header {
  color: #555;
  background-color: #fff;
  width: 100%;
  height: 3.5rem;
  border-bottom: 1px solid #eee;
  padding: 4px 0;
}

.cat-header-inner {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: start;
  -ms-flex-align: center;
      align-items: center;
  width: 67.5rem;
  margin: 0 auto;
  height: 3rem;
  padding: 0.5rem 1rem;
}

.cat-header-image {
  height: 42px;
  width: 42px;
}

.cat-header-image img {
  width: 100%;
  height: 100%;
  border-radius: 10px;
}

.cat-header-name {
  font-size: 16px;
  font-weight: 700;
  color: #555;
  margin-left: 8px;
}

.cat-header a {
  color: #555;
}

.cat-header a:hover {
  color: #888888;
  text-decoration: underline;
}

@media screen and (max-width: 768px) {
  .cat-header {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
        align-items: center;
  }
  .cat-header div.header-inner {
    -ms-flex-pack: start;
        justify-content: start;
  }
}

@media screen and (min-width: 769px) {
  .cat-header.site-takeover-cat-header {
    position: absolute;
    top: 3rem;
    z-index: 98;
  }
  .cat-header.site-takeover-cat-header.has-header-takeover {
    position: absolute;
    top: 4rem;
  }
}

/**
 * Title
 */
.flag, .flag-showing, .flag-coming {
  position: absolute;
  top: 0;
  left: 0;
  opacity: .9;
  z-index: 10;
  color: #fff;
  font-weight: bold;
}

.flag.small, .small.flag-showing, .small.flag-coming {
  transform: scale(0.8);
  transform-origin: top left;
}

.flag-showing {
  width: 2rem;
  height: 4rem;
  padding: .3rem 0;
  background: url("/images/flag_showing.png") no-repeat left top;
  background-size: contain;
  text-indent: -9999px;
}

.flag-coming {
  width: 3rem;
  height: 3rem;
  padding: .2rem;
  line-height: 1.15;
  text-align: center;
  background: url("/images/flag_coming.png") no-repeat left top;
  background-size: contain;
}

.flag-coming > div {
  font-size: .6rem;
}

.flag-coming > div.flag-main {
  font-size: .8rem;
}

.flag-coming > div.flag-main:first-child {
  margin-top: .35rem;
}

.title-poster-flag {
  position: relative;
  transition: all .25s ease-out;
}

.title-poster-flag .img-title-poster {
  width: 100%;
  height: auto;
}

.title-rating {
  color: #e0b10d;
}

.title-rating span {
  display: inline-block;
  margin-left: .5rem;
  font-size: 1.2rem;
  font-weight: bolder;
}

.title-action-counts {
  background: #eee;
  display: inline-block;
  padding: .5rem;
  border-radius: 3px;
}

.title-action-counts .title-action-counts-content {
  display: -ms-flexbox;
  display: flex;
  font-weight: 600;
  font-size: .8rem;
  -ms-flex-pack: start;
      justify-content: flex-start;
}

.title-action-counts .title-action-counts-content .icon {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  height: .75rem;
}

.title-action-counts .title-action-counts-content > * {
  -ms-flex-positive: 0;
      flex-grow: 0;
  margin: 0 .5rem 0 0;
}

.title-action-counts .title-action-counts-content > *:last-of-type {
  margin: 0;
}

.title-item-poster {
  display: block;
  width: 10rem;
  color: #555;
}

.title-item-poster:hover {
  color: #555;
  opacity: .7;
}

.title-item-poster .title-item-poseter-info {
  background: #f9f9f9;
  padding: .25rem .5rem;
}

.title-item-poster .title-item-poseter-info .title {
  margin-bottom: 0;
  padding: 0 0 .1rem;
  font-weight: bold;
  font-size: .8rem;
  line-height: 1.25;
  text-align: center;
}

.title-item-poster .title-item-poseter-info .score {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  font-weight: bold;
}

.title-item-poster .title-item-poseter-info .score > * {
  position: relative;
  width: 33.3%;
  text-align: center;
}

.title-item-poster .title-item-poseter-info .score > * a, .title-item-poster .title-item-poseter-info .score > * span {
  display: block;
  padding: 1.2rem 0 0;
}

.title-item-poster .title-item-poseter-info .score > * a::before, .title-item-poster .title-item-poseter-info .score > * span::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: '';
  margin: auto;
  background-repeat: no-repeat;
  background-size: contain;
}

.title-item-poster .title-item-poseter-info .score > * a.num, .title-item-poster .title-item-poseter-info .score > * span.num {
  white-space: nowrap;
}

.title-item-poster .title-item-poseter-info .score .avg-rating span {
  color: #e0b10d;
}

.title-item-poster .title-item-poseter-info .score .avg-rating span::before {
  width: 1rem;
  height: 1rem;
  margin: 0 auto;
  background-image: url("/images/icon_star@2x.png");
}

.title-item-poster .title-item-poseter-info .score .count-seen span::before {
  width: 18px;
  height: 15px;
  margin: .15rem auto 0;
  background-image: url("/images/seen_black@2x.png");
}

.title-item-poster .title-item-poseter-info .score .count-want span::before {
  width: 1rem;
  height: 1rem;
  margin: 0 auto;
  background-image: url("/images/want_black@2x.png");
}

@media screen and (max-width: 768px) {
  .title-item-poster .title-item-poseter-info .title {
    font-size: .7rem;
  }
}

.date-list {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: .5rem;
}

.date-list .date-item {
  width: 15%;
  margin: 0 .3rem .75rem;
}

.date-item {
  color: #555;
  padding: .75rem 1rem;
  background: #f9f9f9;
  border: 1px;
  border-radius: .5rem;
  font-weight: 600;
  text-align: center;
}

.date-item:hover {
  color: #f11a38;
  opacity: .5;
}

@media screen and (max-width: 768px) {
  .date-list .date-item {
    width: 30%;
    min-width: 4.5rem;
  }
}

.grid-title-item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: 1rem 0 0 1rem;
}

.grid-title-item .no-item {
  padding: 0 1rem 1rem;
  color: #555;
  background: #fff;
}

.grid-title-item.is-poster .grid-title-item-unit {
  width: 25%;
  padding: 0 1rem 1rem 0;
}

.grid-title-item.is-poster .grid-title-item-unit .title-item-poster {
  width: 100%;
}

.grid-title-item.is-card .grid-title-item-unit {
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  padding: 0 1rem 1rem 0;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .grid-title-item {
    padding: .5rem 0 0 .5rem;
  }
  .grid-title-item.is-poster .grid-title-item-unit {
    width: 33.33%;
    padding: 0 .5rem .5rem 0;
  }
  .grid-title-item.is-card {
    padding: 1rem 0;
  }
  .grid-title-item.is-card .grid-title-item-unit {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    padding: 0 0 1rem;
  }
  .grid-title-item.is-card .grid-title-item-unit:last-of-type {
    padding: 0;
  }
}

.title-nav-menu .nav-menu-content {
  display: -ms-flexbox;
  display: flex;
}

.title-nav-menu .nav-menu-item {
  -ms-flex: 1;
      flex: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.title-nav-menu .nav-menu-item a {
  color: #555;
}

.title-nav-menu .nav-menu-item a:hover {
  color: #888888;
  text-decoration: underline;
}

.title-nav-menu .nav-menu-item a {
  display: block;
  padding: .5rem 0;
  background: #f9f9f9;
}

.title-nav-menu .nav-menu-item .nav-menu-item-content {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-direction: column;
      flex-direction: column;
  height: 3rem;
  font-size: .8rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.25;
  border-right: 1px solid #e3e3e3;
}

.title-nav-menu .nav-menu-item:last-child .nav-menu-item-content {
  border-right: none;
}

.title-nav-menu .nav-menu-item.is-active a {
  color: #aaa;
}

@media screen and (max-width: 768px) {
  .title-nav-menu .nav-menu-item .nav-menu-item-content {
    height: 2rem;
    font-size: .7rem;
  }
}

/**
 * Person
 */
.person-item {
  display: block;
  margin: 0 0 .5rem;
  padding: .5rem;
  border: 1px solid #eee;
  border-radius: 3px;
  color: #555;
}

.person-item span {
  display: block;
}

.person-item .role {
  padding-top: .25rem;
  font-size: 80%;
  color: #aaa;
}

.person-item:hover {
  opacity: .7;
}

.person-item.large {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: start;
      align-items: flex-start;
  padding: 0;
}

.person-item.large .person-item-text {
  padding: 1rem;
}

.person-item.large .person-item-text .name {
  font-weight: bold;
}

.person-item.large .person-item-text .biography {
  padding-top: .5rem;
  color: #aaa;
}

.person-item.small {
  display: inline-block;
  font-size: .7rem;
  line-height: 1.1rem;
  padding: .25rem .4rem;
  border: none;
  border-radius: 100px;
  background: #eee;
}

.person-item.small:last-child {
  margin: 0;
}

.person-list .person-list-item:last-child .person-item {
  margin-bottom: 0;
}

/**
 * User
 */
/**
     * WriterList
     */
.writer-list > li {
  padding: 0 0 1rem 0;
}

/**
     * WriterItem
     */
.writer-item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: flex-start;
}

.writer-item .writer-thumb {
  margin-right: 1rem;
}

.writer-item .writer-thumb a {
  display: inline-block;
  border-radius: 50%;
  overflow: hidden;
}

.writer-item .writer-thumb img {
  width: 100px;
  height: 100px;
}

.writer-item .writer-text .writer-name {
  display: inline-block;
  font-weight: bold;
  font-size: 0.9rem;
  padding-bottom: 0.5rem;
}

.writer-item .writer-text .writer-profile {
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .writer-item .writer-thumb img {
    width: 80px;
    height: 80px;
  }
  .writer-item .writer-text .writer-profile {
    font-size: 0.75rem;
  }
}

/**
 * NewsLetter
 */
.news-letter-item {
  clear: left;
}

.news-letter-form {
  position: relative;
  padding-bottom: 1rem;
}

.news-letter-label {
  display: block;
  line-height: 1.7;
  font-weight: normal;
  padding: 0;
  margin-bottom: 0.5rem;
}

.news-letter-email-input {
  padding: 0 0.4em;
  border: 1px solid #555;
  margin-bottom: 0.8rem;
  -webkit-appearance: none;
}

.news-letter-spam-input {
  position: absolute;
  left: -5000px;
}

.news-letter-submit-button {
  clear: none;
  display: inline;
}

.news-letter-submit-button input {
  cursor: pointer;
  display: block;
  color: #fff;
  background-color: #f11a38;
  font-weight: bold;
  height: 32px;
  width: 140px;
  clear: both;
  border: 0 none;
  border-radius: 8px;
  letter-spacing: 0.03em;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  transition: all 0.23s ease-in-out 0s;
}

/**
 * Validation
 */
.invalid-feedback {
  color: #fdaa1b;
}

.index-box {
  line-height: 0;
  background-color: #fff;
  /* The Modal (background) */
}

.index-box .index-wrapper {
  border: 1px solid #aaa;
}

.index-box .index-content {
  padding: 1.5rem 1.5rem 0;
}

.index-box .index-content .index-title {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.index-box .index-content .index-title .index-icon {
  position: relative;
  width: 18px;
  height: 15px;
  min-height: auto;
  margin-right: 0.4rem;
}

.index-box .index-content .index-title .index-title-text {
  font-size: 110%;
  color: #777;
  line-height: 1;
  white-space: nowrap;
}

.index-box .index-content ul {
  list-style-type: disc;
  display: block;
  position: relative;
  padding-left: 1rem;
}

.index-box .index-content ul[class="is-closed"] {
  max-height: 13rem;
  overflow: hidden;
  margin: 1rem 0 0.5rem;
}

.index-box .index-content ul[class="is-closed"]::after {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  content: "";
  width: 100%;
  height: 25%;
  background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0.7) 50%, #fff 88%);
}

.index-box .index-content ul[class="is-shown"] {
  margin: 1rem 0;
}

.index-box .index-content ul li {
  line-height: 1.5;
  margin-bottom: 0.5rem;
}

.index-box .index-content ul li a {
  color: #0d95b3;
}

.index-box .index-content ul li a:hover {
  color: #6ebfd1;
  text-decoration: underline;
}

.index-box .index-content ul li::marker {
  color: #777;
}

.index-box .index-content ul li.is-hidden {
  display: none;
}

.index-box .index-handler {
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
}

.index-box .index-handler input {
  width: initial;
  height: auto;
  border: initial;
  margin: initial;
}

.index-box .index-handler .index-handler-switch {
  display: inline-block;
  text-align: center;
  font-weight: 400;
  color: #777;
  padding: 1.5rem;
  width: 100%;
  cursor: pointer;
  transition: all 0.25s ease-out;
}

.index-box .index-handler .index-handler-switch::after {
  display: inline-block;
  position: absolute;
  content: "";
  top: 1.05rem;
  width: 5px;
  height: 5px;
  border: 2px solid;
  border-color: #565656 #565656 transparent transparent;
  margin-left: 0.3rem;
  transform: rotate(135deg);
}

.index-box .index-handler .index-handler-switch:hover {
  background-color: #f9f9f9;
}

.index-box .index-handler .index-handler-checkbox:checked + .index-handler-switch::after {
  top: 1.35rem;
  transform: rotate(315deg);
}

.index-box .index-fixed-wrapper button.index-fixed-button {
  position: fixed;
  bottom: 200px;
  right: -1px;
  z-index: 10;
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid #12d5ff;
  border-radius: 8px 0 0 8px;
  box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.15);
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  line-height: 1;
}

.index-box .index-fixed-wrapper button.index-fixed-button:hover {
  text-decoration: none;
}

.index-box .index-fixed-wrapper button.index-fixed-button .index-fixed-icon {
  width: 18px;
  height: 15px;
  min-height: auto;
  margin: 0 auto;
}

.index-box .index-fixed-wrapper button.index-fixed-button .index-fixed-label {
  font-size: 10px;
  margin-top: 2px;
}

.index-box .index-fixed-wrapper a {
  color: #555;
}

.index-box .index-fixed-wrapper a:hover {
  color: #888888;
  text-decoration: underline;
}

.index-box .index-modal {
  display: none;
  /* Case of close 'none', Case of open 'flex'. */
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: center;
      justify-content: center;
  position: fixed;
  line-height: 1;
  background-color: rgba(0, 0, 0, 0.7);
  /* Black w/ opacity */
  z-index: 100;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  /* Modal Content */
}

.index-box .index-modal .index-modal-content-wrapper {
  background-color: #fff;
  margin: 1rem 1rem 256px;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  height: 100%;
  max-height: calc(100vh - 1rem - 256px);
  padding: 1.5rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__head {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
  line-height: 0;
  color: #777;
  padding-bottom: 1rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__head .title {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__head .title__icon {
  width: 18px;
  height: 15px;
  min-height: auto;
  margin-right: 0.4rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__head .title__text {
  font-size: 110%;
  line-height: 0;
  white-space: nowrap;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__head .close-button {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  font-size: 1.8rem;
  font-weight: bold;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__main {
  line-height: 1.5;
  overflow-y: scroll;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content__main a {
  color: #0d95b3;
  cursor: pointer;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .index-accordion-head {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: start;
      align-items: flex-start;
  font-weight: bold;
  padding: 0.3rem 0;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .index-accordion-head a {
  margin-left: 0.8rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .index-accordion-head__switch {
  display: inline-block;
  background-color: #fff;
  border: solid #777;
  border-width: 0 0.13rem 0.13rem 0;
  padding: 0.3rem;
  margin: 0.26rem 0.1rem 0.1rem;
  transform: rotate(-45deg);
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .index-accordion-panel {
  padding: 0 18px;
  background-color: white;
  overflow: hidden;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .index-accordion-active {
  margin: 0.1rem;
  transform: rotate(45deg);
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .disc-list {
  list-style: disc;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .circle-list {
  list-style: circle;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .one-level-indent {
  padding-left: 1rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .two-level-indent {
  padding-left: 2rem;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .lowest-list-item {
  padding: 0.2rem 0;
  font-size: 14px;
}

.index-box .index-modal .index-modal-content-wrapper .index-modal-content .lowest-list-item::marker {
  color: #777;
}

@media screen and (max-width: 768px) {
  .index-box .index-content {
    padding: 1rem 1rem 0;
  }
  .index-box .index-content ul[class="is-shown"] {
    margin: 1rem 0;
  }
  .index-box .index-handler .index-handler-switch {
    padding: 1rem;
  }
  .index-box .index-handler .index-handler-switch::after {
    top: 0.5rem;
  }
  .index-box .index-handler .index-handler-switch:hover {
    background-color: inherit;
  }
  .index-box .index-handler .index-handler-checkbox:checked + .index-handler-switch:after {
    top: 0.9rem;
  }
}

/**
     * Web IconFont
     */
@font-face {
  font-family: 'icomoon';
  src: url("fonts/icomoon.eot?dkeyi9");
  src: url("fonts/icomoon.eot?dkeyi9#iefix") format("embedded-opentype"), url("fonts/icomoon.ttf?dkeyi9") format("truetype"), url("fonts/icomoon.woff?dkeyi9") format("woff"), url("fonts/icomoon.svg?dkeyi9#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

video-js.overlay {
  position: fixed !important;
  z-index: 2147483647 !important;
  inset: auto 15px 15px auto !important;
}

video-js .vjs-control.vjs-visible-text.origin {
  display: none;
}

video-js .vjs-picture-in-picture-control {
  display: none !important;
}

.video-js .vjs-control.vjs-visible-text.closeButton {
  border-radius: 50%;
  border: 2px solid #fff;
  margin: auto 1em;
  padding: 0;
  width: 1rem;
  height: 1rem;
  position: relative;
}

.video-js .vjs-control.vjs-visible-text.closeButton::before, .video-js .vjs-control.vjs-visible-text.closeButton::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2px;
  height: 0.5rem;
  background: #fff;
}

.video-js .vjs-control.vjs-visible-text.closeButton::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.video-js .vjs-control.vjs-visible-text.closeButton::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

@media screen and (max-width: 768px) {
  video-js.overlay {
    inset: 0 !important;
  }
}

/* =====================
 * Layouts
 * ===================== */
/* ===========================
     * Main Layout
     * =========================== */
.content {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  width: 67.5rem;
  margin: 0 auto;
  padding: 0;
}

.content.only {
  padding: 1rem 0;
  background-color: #fff;
}

/* ===========================
     * Main Content
     * =========================== */
.main-content {
  width: 47.5rem;
  background: #fff;
}

.main-content-head {
  padding: 2rem 1rem 0;
}

.main-content-head.sub {
  padding: 2rem 0.5rem 0.5rem;
}

.main-content-head.sub .head-sub {
  margin: 0;
}

/* ===========================
     * SideBar
     * =========================== */
.sidebar {
  width: 20rem;
  background: #fff;
}

/* ===========================
     * Layout Parts
     * =========================== */
.main-unit {
  padding: 1rem;
}

.main-unit.no-p-top {
  padding-top: 0;
}

.main-unit.no-p-bottom {
  padding-bottom: 0;
}

.main-unit.no-p-side {
  padding-right: 0;
  padding-left: 0;
}

.main-desc p {
  padding: 1rem;
  background: #eee;
  color: #555;
  font-size: 90%;
  white-space: normal;
}

.link-aside {
  padding: 0.5rem 1rem;
  text-align: right;
}

.link-aside a {
  color: #aaa;
}

.link-aside a:hover {
  color: #717171;
  text-decoration: underline;
}

.link-aside a {
  display: inline-block;
  font-size: 90%;
}

.link-aside a::after {
  display: inline-block;
  content: "";
  width: 0.5rem;
  height: 0.5rem;
  margin-left: 0.5rem;
  border-top: 2px solid #aaa;
  border-right: 2px solid #aaa;
  transform: rotate(45deg);
}

.link-aside a:hover::after {
  border-top: 2px solid #717171;
  border-right: 2px solid #717171;
}

.link-aside.no-p-side {
  padding-right: 0;
  padding-left: 0;
}

/* ===========================
     * Margin for fixed header contents
     * =========================== */
.scrollable-area.articlepage {
  margin-top: 3.5rem;
}

.scrollable-area.articlepage.has-header-takeover {
  margin-top: 7.5rem;
}

.scrollable-area.toppage.has-header-takeover {
  margin-top: 4rem;
}

@media screen and (max-width: 768px) {
  .content,
  .main-content,
  .sidebar {
    display: block;
    width: 100%;
  }
  .content.only {
    padding: 0;
  }
  .scrollable-area.articlepage, .scrollable-area.toppage {
    margin-top: 0;
  }
  .scrollable-area.articlepage.has-header-takeover, .scrollable-area.toppage.has-header-takeover {
    margin-top: 3rem;
  }
}

.header {
  color: #555;
  background-color: #fff;
  width: 100%;
  border-bottom: 1px solid #eee;
  height: 3rem;
}

.header .header-inner {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: start;
  -ms-flex-align: center;
      align-items: center;
  width: 67.5rem;
  margin: 0 auto;
  height: 3rem;
  padding: 0.5rem 1rem;
}

.header .header-item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: flex-start;
}

.header .site-title {
  margin: 0;
  padding-right: 1rem;
}

.header .header-logo-img {
  width: 102px;
  height: 32px;
}

.header .header-text {
  font-size: 0.8rem;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: end;
      align-items: flex-end;
}

.header .header-text-subtitle {
  display: block;
  margin-left: 8px;
}

.header .header-text-title {
  display: block;
}

.mobile .header .header-inner {
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.site-takeover-header {
  position: fixed;
  top: 0;
  color: #555;
  background-color: #fff;
  width: 100%;
  border-bottom: 1px solid #eee;
  height: 4rem;
  z-index: 99;
}

.site-takeover-header .header-inner {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: start;
  -ms-flex-align: center;
      align-items: center;
  width: 67.5rem;
  margin: 0 auto;
  height: 4rem;
  padding: 0 1rem;
}

.site-takeover-header .header-item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
}

.site-takeover-header .header-logo-img {
  width: 81.6px;
  height: 25.6px;
}

.site-takeover-header .header-text {
  font-size: 0.8rem;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: end;
      align-items: flex-end;
  padding-top: 6px;
  margin: auto;
}

.site-takeover-header .header-text-subtitle {
  display: block;
  margin-left: 8px;
}

.site-takeover-header .header-text-title {
  display: block;
}

.site-takeover-header .partition-image {
  height: 18px;
  margin: 0 0.4rem 0 0.7rem;
}

.site-takeover-header .takeover-logo {
  height: 48px;
}

@media screen and (max-width: 768px) {
  .header {
    border-bottom: 1px solid #eee;
    background-color: #fff;
    height: 2.25rem;
  }
  .header .header-inner {
    -ms-flex-pack: justify;
        justify-content: space-between;
    width: 100%;
    height: 2.25rem;
  }
  .header .header-inner .site-title {
    padding-right: 0.5rem;
  }
  .header .header-inner .header-logo-img {
    width: 61.2px;
    height: 19.2px;
  }
  .header .header-inner .header-text {
    -ms-flex-item-align: end;
        align-self: flex-end;
    font-size: 0.6rem;
  }
  .header .header-inner .header-text-subtitle {
    display: none;
  }
  .site-takeover-header {
    position: fixed;
    top: 0;
    border-bottom: 1px solid #eee;
    height: 3rem;
  }
  .site-takeover-header .header-inner {
    -ms-flex-pack: center;
        justify-content: center;
    width: 100%;
    height: 3rem;
    position: relative;
    background-size: cover;
  }
  .site-takeover-header .header-inner .site-item {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
        flex-direction: column;
  }
  .site-takeover-header .header-inner .header-logo-img {
    width: 61.2px;
    height: 19.2px;
  }
  .site-takeover-header .header-inner .header-text {
    font-size: 0.6rem;
  }
  .site-takeover-header .header-inner .header-text-subtitle {
    display: none;
  }
  .site-takeover-header .header-inner .partition-image {
    height: 16px;
    margin: 0 0.5rem;
  }
  .site-takeover-header .header-inner .takeover-logo {
    height: 36px;
  }
  .site-takeover-header .header-inner .header-search {
    position: absolute;
    right: 1rem;
  }
}

.footer {
  color: #555;
  width: 67.5rem;
  margin: 0 auto;
}

.footer .footer-inner {
  padding: .5rem;
}

.footer .footer-nav {
  padding: 1rem 1rem 2rem;
  background: #fff;
}

.footer .footer-nav-grid, .footer .footer-nav-list-wrap {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.footer .footer-nav-item, .footer .footer-nav-list {
  -ms-flex: 1 0 auto;
      flex: 1 0 auto;
}

.footer .footer-nav-item.double, .footer .footer-nav-list.double {
  -ms-flex: 2 0 auto;
      flex: 2 0 auto;
}

.footer .footer-nav-head {
  margin-bottom: .75rem;
  font-size: 1rem;
}

.footer .footer-nav-list li {
  display: block;
  padding: .5rem 0;
  font-size: 90%;
}

.footer .footer-nav-list li a {
  color: #555;
}

.footer .footer-nav-list li a:hover {
  color: #888888;
  text-decoration: underline;
}

.footer .footer-bottom {
  font-size: 90%;
  line-height: 1.5;
}

.footer .footer-bottom .footer-copyright {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  height: 10rem;
  line-height: 2rem;
}

.footer .footer-bottom .footer-copyright a {
  color: #555;
}

.footer .footer-bottom .footer-copyright a:hover {
  color: #888888;
  text-decoration: underline;
}

@media screen and (max-width: 768px) {
  .footer {
    width: 100%;
  }
  .footer .footer-inner {
    padding: 0;
  }
  .footer .footer-nav {
    padding: 0;
  }
  .footer .footer-menu {
    padding: 1rem 1rem;
  }
  .footer .footer-menu-item {
    padding: 1rem 0;
  }
  .footer .footer-menu-item a {
    color: #555;
  }
  .footer .footer-menu-item a:hover {
    color: #888888;
    text-decoration: underline;
  }
  .footer .footer-menu-head {
    margin-bottom: .5rem;
    font-size: 1rem;
  }
  .footer .footer-menu-list {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .footer .footer-menu-list li {
    width: 50%;
    box-sizing: border-box;
    padding: 1rem 0 0;
  }
  .footer .footer-bottom .footer-inner {
    padding: 1.5rem 1rem;
  }
  .footer .footer-bottom .footer-copyright {
    -ms-flex-direction: column;
        flex-direction: column;
    text-align: center;
  }
  .footer .copyright {
    padding-top: 1.5rem;
  }
}

.sidebar-unit {
  padding: 1rem;
}

.sidebar-unit.full {
  padding: 1rem 0;
}

.sidebar-unit:last-child {
  margin: 0;
}

.sidebar-unit .sidebar-fb-widget {
  text-align: center;
}

.sidebar-unit img {
  max-width: 100%;
}

.sidebar-unit .link-aside-button {
  padding: 0.5rem 0 1rem 0;
}

.sidebar {
  padding-top: 1rem;
}

.sidebar .article-item {
  padding-right: 0;
  padding-left: 0;
}

.sidebar .article-item .article-item-heading {
  overflow: hidden;
  white-space: normal;
}

.sidebar .sticky-container {
  height: 100rem;
  margin: 1rem 0;
}

.sidebar .sticky-top {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
}

/* =====================
 * Pages
 * ===================== */
.hero-panel {
  display: -ms-flexbox;
  display: flex;
  height: 30rem;
  background: #555;
  overflow: hidden;
}

.hero-panel-main {
  height: 100%;
}

.hero-panel-main.hero-panel-item {
  width: 60%;
  height: 100%;
}

.hero-panel-main.hero-panel-item .article-name {
  padding-right: 4rem;
  padding-left: 4rem;
  font-size: 1.75rem;
  line-height: 1.5;
}

.hero-panel-side {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 40%;
  height: 100%;
}

.hero-panel-item {
  display: block;
  position: relative;
  width: 100%;
  height: 50%;
  background-position: center center;
  background-size: cover;
}

.hero-panel-item .article-name {
  margin: 0;
  padding: 2rem;
  font-size: 1.25rem;
  line-height: 1.5;
  color: #fff;
}

.hero-panel-item .label-pr {
  position: absolute;
  top: 1rem;
  right: 1rem;
  border: 1px solid #fff;
  color: #fff;
}

.hero-panel-item-bg {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: end;
      align-items: flex-end;
  height: 100%;
  background: rgba(85, 85, 85, 0.3);
  transition: all .25s ease-out;
}

.hero-panel-item-bg:hover {
  background: rgba(241, 26, 56, 0.3);
}

@media screen and (max-width: 768px) {
  .hero-panel {
    -ms-flex-line-pack: stretch;
        align-content: stretch;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    height: 32rem;
  }
  .hero-panel-main, .hero-panel-side {
    width: 100%;
  }
  .hero-panel-item .article-name {
    padding: 1rem;
    font-size: .9rem;
  }
  .hero-panel-main.hero-panel-item {
    width: 100%;
    height: 60%;
  }
  .hero-panel-main.hero-panel-item .article-name {
    padding: 1.5rem 1rem;
    font-size: 1.3rem;
  }
  .hero-panel-side {
    height: 40%;
  }
}

.category-header h1 {
  margin: 0;
}

.feature-header {
  background-color: #eee;
  padding: 1.5rem 1rem 1rem;
}

.feature-header__item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: flex-start;
  -ms-flex-align: center;
      align-items: center;
  text-align: center;
  padding-bottom: .6rem;
}

.feature-header__item .img-cover {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  height: 5rem;
  width: 5rem;
  border-radius: 50%;
}

.feature-header__item .img-cover img {
  width: 100%;
  height: 100%;
}

.feature-title {
  padding-left: 1rem;
  text-align: left;
}

.feature-title p {
  font-size: .8rem;
  font-weight: bold;
  line-height: 1.4;
  margin: 0;
}

.feature-title h1 {
  font-size: 1.2rem;
  color: #555;
  line-height: 1.3;
  margin: 0;
}

.feature-header__source {
  color: #aaa;
  font-size: .7rem;
}

.feature-header .main-desc p {
  padding: 1.3rem 0 0;
}

.tag .tag-header {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: flex-start;
  -ms-flex-align: center;
      align-items: center;
  height: 8rem;
  padding: 0 1rem;
}

.tag .tag-thumb {
  margin-right: 1rem;
}

.tag .tag-thumb .img-cover {
  width: 5rem;
  height: 5rem;
  border-radius: 50%;
}

.tag .tag-thumb .img-cover img {
  width: 100%;
  height: 100%;
}

.tag .tag-head {
  margin: 0;
}

@media screen and (max-width: 768px) {
  .main-content-head {
    padding-top: 1rem;
  }
}

.title .title-nav-menu {
  padding-bottom: 1rem;
}

.title-header .title-header-unit {
  padding: 1rem 1rem 0;
}

.title-header .title-header-unit.is-last {
  padding: 1rem;
}

.title-header .title-header-unit .title-heading-main {
  margin: 0;
  font-size: 1.5rem;
  font-weight: bolder;
  line-height: 1.5;
}

.title-header .title-header-unit .title-header-detail-text {
  color: #717171;
  font-size: .8rem;
  line-height: 1.5;
}

.title-header .title-header-unit .title-header-detail-text a {
  color: #717171;
  text-decoration: underline;
}

.title-header .title-header-unit .title-header-detail-text a:hover {
  opacity: .7;
}

.title-header .title-header-unit .title-header-content {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: flex-start;
}

.title-header .title-header-unit .title-header-content .left {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 12rem;
}

.title-header .title-header-unit .title-header-content .right {
  padding: .5rem 0 0 1rem;
}

.title-header .title-header-unit .title-header-content .title-header-content-item {
  padding-bottom: 1rem;
}

.title-header .title-header-unit .title-header-content .title-header-content-item .link-text {
  color: #717171;
  text-decoration: underline;
  font-size: .8rem;
  padding-left: .5rem;
}

.title-header .title-header-unit .title-header-content .title-header-content-item .link-text:hover {
  opacity: .7;
}

.title-header .title-header-unit .title-header-content .title-header-content-item .btn {
  margin: 0;
}

.title-body .copyright {
  font-size: 90%;
  text-align: right;
}

.title-body .person-row {
  display: -ms-flexbox;
  display: flex;
  padding: 1rem 0 1rem 1rem;
}

.title-body .person-row .person-column {
  width: 50%;
  padding-right: 1rem;
}

@media screen and (max-width: 768px) {
  .title-header .title-header-unit .title-heading-main {
    font-size: 1.15rem;
  }
  .title-header .title-header-unit .title-header-content .left {
    width: 9rem;
  }
  .title .title-body .person-row {
    -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
  }
  .title .title-body .person-row .person-column {
    width: 100%;
    padding-bottom: .5rem;
  }
  .title .title-body .person-row .staffs .head-sub {
    margin-top: 1rem;
  }
}

.writer .writer-thumb {
  margin-right: 1rem;
}

.writer .writer-thumb .img-cover {
  width: 100px;
  height: 100px;
  border-radius: 50%;
}

.writer .writer-thumb .img-cover img {
  width: 100%;
  height: 100%;
}

.writer .writer-header {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: flex-start;
}

.writer .writer-header .writer-text {
  padding-top: .5rem;
}

.writer .writer-header .writer-text .writer-head {
  font-size: 1.1rem;
}

.writer .writer-header .writer-text .writer-profile {
  font-size: .8rem;
}

@media screen and (max-width: 768px) {
  .writer-header {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: start;
        justify-content: flex-start;
  }
  .writer-header .writer-text {
    padding-top: .5rem;
  }
  .writer-header .writer-text .writer-head {
    font-size: 1.1rem;
  }
  .writer-header .writer-text .writer-profile {
    font-size: .8rem;
  }
}

.user .user-content-container {
  margin: 5% auto;
  max-width: 90%;
}

.user .user-content-container.with-display-flex {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-direction: column;
      flex-direction: column;
}

.user .user-content-container.with-table table {
  width: 100%;
}

.user .user-content-container.with-table table td {
  padding: 10px;
}

.user .user-content-container.with-table table th {
  width: 30%;
  padding: 5px;
}

.static p, .static h2, .static ul {
  margin-bottom: 1rem;
}

.static .about p, .static .about h2, .static .about ul {
  margin-bottom: 3rem;
}

.static .about h2 {
  font-size: 180%;
}

.static .about h3 {
  font-size: 150%;
}

.static .about .head-main {
  font-size: 200%;
}

.static .about .margin-bottom-zero {
  margin-bottom: 0rem;
}

.static .about .feature-display {
  display: -ms-flexbox;
  display: flex;
  font-size: 120%;
  margin-bottom: 5rem;
}

.static .about .form {
  display: block;
  margin: auto;
  width: 80%;
}

.static .about .form-a {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  width: 90%;
  font-size: 90%;
  color: #f11a38;
  border: 2px solid #f11a38;
  border-radius: 2rem;
  padding: .75rem .1rem;
}

.static .about .image-about-page {
  text-align: center;
}

.static .about .image-about-page img {
  width: 95%;
}

.static .about .head-main-text {
  font-size: 120%;
  margin-bottom: 4rem;
  margin-top: 1rem;
}

.static .about .feature-text {
  margin: 0rem 2rem 0rem 2rem;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: center;
      justify-content: center;
}

.static .about .recruit {
  font-size: 120%;
}

.static h2 {
  font-size: 120%;
}

.static h3 {
  font-size: 105%;
}

.static h2 a, .static h3 a {
  color: #555;
}

.static h2 a:hover, .static h3 a:hover {
  color: #888888;
  text-decoration: underline;
}

.static h2 a, .static h3 a {
  position: relative;
}

.static h2 a::after, .static h3 a::after {
  display: inline-block;
  position: absolute;
  top: .25rem;
  content: '';
  width: .5rem;
  height: .5rem;
  margin-left: .5rem;
  border-top: 2px solid #555;
  border-right: 2px solid #555;
  transform: rotate(45deg);
}

.static h2 a:hover, .static h3 a:hover {
  opacity: .7;
}

.static li {
  line-height: 1.75;
}

.static ol {
  list-style-type: none;
}

.static table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  margin-bottom: 1rem;
}

.static table th, .static table td {
  border: 1px solid #555;
  padding: .5rem;
}

.static table th {
  font-size: 105%;
  font-weight: normal;
}

.static .sitemap-row {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.static .sitemap-row .sitemap-grid {
  width: 33%;
  padding-right: 1rem;
}

.static .indent {
  padding-left: 1rem;
}

@media screen and (max-width: 768px) {
  .static .sitemap-row {
    display: block;
  }
  .static .sitemap-row .sitemap-grid {
    width: 100%;
    padding-right: 0;
  }
  .static .about .feature-display {
    display: block;
  }
  .static .about .feature-text {
    margin: 0rem;
  }
}

.errors {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-direction: column;
      flex-direction: column;
  min-height: 30rem;
}

.errors h1 {
  text-align: center;
}

.errors > * {
  margin-bottom: 2rem;
}

.errors p {
  padding: 0 1rem;
}

/*
     * contentFull Main Layout
     */
.content-full {
  width: 100%;
}

.content-full-inner {
  width: 67.5rem;
  margin: 0 auto;
  background: #fff;
}

/*
     * content Main Layout
     */
.top-main {
  padding-top: 2rem;
}

.link-aside-button {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  padding: 0.5rem 1rem 2rem 1rem;
  margin: 0 0 1rem;
}

.link-aside-button a {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  width: 100%;
  max-width: 30rem;
  font-size: 90%;
  font-weight: bold;
  color: #777;
  padding: 0.75rem 0.5rem;
  border: 2px solid #777;
  border-radius: 2rem;
}

.link-aside-button a::after {
  display: inline-block;
  content: "";
  width: 0.5rem;
  height: 0.5rem;
  margin-left: 0.5rem;
  border-top: 2px solid #777;
  border-right: 2px solid #777;
  transform: rotate(45deg);
}

.link-aside-button a:hover {
  text-decoration: underline;
  opacity: 0.7;
}

.link-aside-button a:hover::after {
  opacity: 0.7;
}

/*
     * toppage search
     */
.toppage-search {
  width: 67.5rem;
  background: #fff;
  margin: auto;
}

.toppage-search .toppage-search-inner {
  position: relative;
  height: 350px;
  width: 100%;
  text-align: center;
  z-index: 3;
}

.toppage-search .toppage-search-inner img {
  max-width: 100%;
  height: auto;
}

.toppage-search .image-creator {
  font-size: 0.7rem;
  font-weight: bold;
  text-align: right;
  padding: 4px 4px 0 0;
}

.toppage-search .search-slogan {
  position: absolute;
  top: 286px;
  left: 16px;
  font-size: 2.3rem;
  font-weight: bold;
  z-index: 1;
  color: #fff;
}

.toppage-search .input-search-unit .input-search-bar {
  width: 30rem;
  z-index: 2;
}

.toppage-search .input-search-unit .input-search-btn {
  z-index: 3;
}

/*
     * recommend-matome
     */
.recommend-matome-title {
  text-align: center;
  color: #555;
  padding-bottom: 10px;
}

.recommend-list {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: start;
      justify-content: flex-start;
  padding-left: 2.5rem;
}

.recommend-list li {
  -ms-flex-preferred-size: 25%;
      flex-basis: 25%;
  padding: 0.8rem 0.5rem;
}

.recommend-genre {
  display: inline-block;
  color: #555;
}

.recommend-genre:hover {
  color: #f77a8c;
}

.recommend-content {
  display: inline-block;
  vertical-align: middle;
}

.recommend-icon {
  font-size: 1.8em;
  width: 2rem;
}

.recommend-matome-text {
  font-size: 1rem;
  padding-left: 0.5rem;
}

.underline {
  border-bottom: 1px solid #e3e3e3;
  margin: 0.2rem 0 2rem;
}

.icon-sf-movie:before {
  content: "\e900";
  color: #555;
}

.icon-anime-movie:before {
  content: "\e901";
  color: #555;
}

.icon-anime:before {
  content: "\e902";
  color: #555;
}

.icon-comedy-movie:before {
  content: "\e903";
  color: #555;
}

.icon-drama:before {
  content: "\e904";
  color: #555;
}

.icon-fantasy-anime:before {
  content: "\e905";
  color: #555;
}

.icon-hanky-movie:before {
  content: "\e906";
  color: #555;
}

.icon-horror-movie:before {
  content: "\e907";
  color: #555;
}

.icon-jp-movie:before {
  content: "\e908";
  color: #555;
}

.icon-korean-drama:before {
  content: "\e909";
  color: #555;
}

.icon-love-anime:before {
  content: "\e90a";
  color: #555;
}

.icon-love-drama:before {
  content: "\e90b";
  color: #555;
}

.icon-love-movie:before {
  content: "\e90c";
  color: #555;
}

.icon-movie:before {
  content: "\e90d";
  color: #555;
}

.icon-world-drama:before {
  content: "\e90e";
  color: #555;
}

.icon-world-movie:before {
  content: "\e90f";
  color: #555;
}

/*
     * recommend-panel
     */
.recommend-panel {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.recommend-panel .recommend-panel-list {
  width: 22rem;
}

.recommend-panel .article-item-title {
  height: 3.5rem;
}

.recommend-panel .article-item-heading {
  -webkit-line-clamp: 3;
}

@media screen and (min-width: 769px) {
  .recommend-panel {
    margin-right: 1.5rem;
    gap: 2rem;
  }
}

/*
     * pickup
     */
.top-main .main-content-head {
  padding: 0 1rem 0;
}

.pickup-list ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.pickup-list ul .article-item {
  width: 22.5rem;
}

/*
     * Mobile Layout
     */
@media screen and (max-width: 768px) {
  .content-full-inner {
    width: 100%;
  }
  .toppage-search {
    width: 100%;
  }
  .toppage-search .toppage-search-inner {
    height: 150px;
  }
  .toppage-search .toppage-search-inner img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .toppage-search .image-creator {
    display: none;
  }
  .toppage-search .search-slogan {
    color: #fff;
    font-size: 1.1rem;
    top: 116px;
    left: 16px;
  }
  .toppage-search .input-search-unit .input-search-bar {
    width: 18rem;
  }
  .recommend-matome-title {
    padding-bottom: 1rem;
  }
  .recommend-matome-title h3 {
    font-size: 1.1rem;
    margin: 0;
  }
  .recommend-list li {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
  }
  .recommend-icon {
    font-size: 1.5em;
    width: auto;
  }
  .recommend-matome-text {
    padding-left: 0.3rem;
    font-size: 0.88rem;
  }
  .recommend-panel .recommend-panel-list {
    width: 100%;
  }
  .recommend-panel .article-item-heading {
    height: 3.8rem;
    margin-bottom: 0;
  }
  .pickup-list ul .article-item {
    width: 100%;
  }
  .pickup-list ul .article-item .article-item-text {
    width: calc(100vw - 80px - 3rem);
  }
}
