.title-1 {
  font-size: 3rem;
  font-weight: 900;
  line-height: 1.625;
  letter-spacing: .1em;
  text-indent: -.2em;
  margin-bottom: 1.25em;
}
.title-1 img {
  display: block;
  margin: 0 auto .25em;
}
@media (max-width:768px) {
  .title-1 {
    font-size: 2.6rem;
  }
  .title-1 img {
    max-height: 4rem;
  }
}

.title-2 {
  position: relative;
  font-size: 2.2rem;
  font-weight: 700;
  padding-left: 1.4em;
  border-bottom: 1px solid #555;
}
.title-2:before {
  content: '■';
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  color: #df1e50;
}
@media (max-width:768px) {
  .title-2 {
    font-size: 2rem;
  }
}

.btn-1 {
  max-width: 100%;
  width: 300px;
  position: relative;
  display: block;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  cursor: pointer;
  color: #fff;
  padding: 1em;
  background: #555;
  transition: 0.2s;
}
.btn-1:after {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  right: 1em;
  width: 0;
  height: 0;
  border: 6px solid transparent;
  border-left-color: inherit;
  transform: scale(1.5,1);
  margin-top: -4px;
}
.btn-1:hover {
  background: #df1e50;
}
.btn-1.back:after {
  left: 1em;
  right: auto;
  border-left-color: transparent;
  border-right-color: inherit;
}
@media (max-width:768px) {
  .btn-1 {
    font-size: 1.8rem;
  }
}

table.default + *,* + table.default { margin-top:1em }
table.default { width:100% }
table.default tr > th,table.default tr > td {
  vertical-align: top;
  padding: 1em;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
}
table.default tr > th { font-weight:bold; text-align:left; }
@media (max-width:768px) {
  table.default:not(.no-responsive),table.default:not(.no-responsive) tbody,table.default:not(.no-responsive) tr,table.default:not(.no-responsive) tr > * {
    width: 100%;
    display: block;
  }
  table.default:not(.no-responsive) tr > th {
    padding-bottom: 0;
    border-bottom: none;
  }
  table.default:not(.no-responsive) tr > td {
    clear: both;
    border: none;
    padding-top: 0;
  }
  table.default:not(.no-responsive) caption {
    display: block;
    font-weight: bold;
    text-align: left;
    margin-bottom: 0.5em;
  }
}

ul.pager-archive {
  text-align: center;
}
ul.pager-archive li {
  display: inline-block;
  vertical-align: middle;
  margin: 0 3px;
}
ul.pager-archive li a {
  display: block;
  text-decoration: none !important;
  color: inherit;
}
ul.pager-archive li.num a {
  width: 2em;
  line-height: 2;
  background: #fff;
  border: 1px solid #ccc;
}
ul.pager-archive li.num.current a[href],ul.pager-archive li.num a[href]:hover {
  color: #fff;
  background: #df1e50;
  border: 1px solid #df1e50;
}
ul.pager-archive li.prev a,ul.pager-archive li.next a {
  color: #df1e50;
  opacity: 0.5;
}
ul.pager-archive li.prev a[href],ul.pager-archive li.next a[href] {
  opacity: 1;
}
ul.pager-archive li.prev a[href]:hover,ul.pager-archive li.next a[href]:hover {
  text-decoration: underline;
}
ul.pager-single {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
ul.pager-single li a {
  display: inline-block;
  padding: 0.5em 1em;
}
ul.pager-single li a[href] {
  color: #df1e50;
}

#global-nav-btn {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 50px;
  padding-top: 50px;
  height: 0;
  background: #df1e50;
}
#global-nav-btn:before,#global-nav-btn:after,#global-nav-btn span:before {
  content: '';
  position: absolute;
  left: 25%;
  display: block;
  width: 50%;
  height: 0;
  padding-top: 1px;
  background: #fff;
}
#global-nav-btn:before {
  top: 31%;
  transition: 0.2s top, 0.2s transform;
}
#global-nav-btn:after {
  top: 47%;
  transition: 0.2s opacity;
}
#global-nav-btn span:before {
  top: 63%;
  transition: 0.2s top, 0.2s transform;
}
.nav-active #global-nav-btn:before {
  top: 50%;
  transform: rotate(135deg);
}
.nav-active #global-nav-btn:after {
  opacity: 0;
}
.nav-active #global-nav-btn span:before {
  top: 50%;
  transform: rotate(45deg);
}

@media (min-width:769px) { .display-sp{display:none!important} }
@media (min-width:1025px) { .display-tb{display:none!important} }
@media (max-width:768px) { .display-pc{display:none!important} }

#breadcrumb { padding:1em 0 0; }
#breadcrumb ol { letter-spacing:-.4em; }
#breadcrumb ol li { display:inline-block; vertical-align:top; letter-spacing:normal; }
#breadcrumb ol li a { display:inline-block; color:#df1e50; }
#breadcrumb ol li ~ li:before { content:'>'; display:inline-block; margin:0 1em; }
@media (max-width:768px) { #breadcrumb { font-size:0.85em; } }

#pagetop { position:fixed; right:3.125%; bottom:3.125%; z-index:9998; }

ul.default,ol.default { margin-left:1.25em }
ul.default li ~ li,ol.default li ~ li { margin-top:0.4em }
ul.default + *,* + ul.default,ol.default + *,* + ol.default { margin-top:1em }
ul.default li { list-style:disc }
ol.default li { list-style:decimal }

[class*="layout-col"] {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  flex-wrap: wrap;
}
.layout-col-2.reverse { flex-direction:row-reverse }
.layout-col-2 > * { width:48% }
.layout-col-2 > *:nth-child(n+3) { margin-top:4% }
@media (min-width:769px) {
.layout-col-3 > * { width: 30.76%; }
.layout-col-3 > *:nth-child(n+4) { margin-top:7.72%; }
}
@media (max-width:768px) {
.layout-col-3 { display:block }
}

.flex-box {
  position: relative;
  height: 0;
  padding-top: 56.25%;
}
.flex-box > * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.flex-box > img {
  object-fit: cover;
}

[class*="inview"] { opacity:0; visibility:hidden;transition: 1s transform, 1s opacity; }
.inview-up { transform:translate3d(0,40px,0) }
.inview-left { transform:translate3d(40px,0,0) }
.inview-right { transform:translate3d(-40px,0,0) }
.inview-active { transform:translate3d(0,0,0); opacity:1; visibility:visible; }

.d-ib{display:inline-block} .d-b{display:block} .d-i{display:inline}
.c-red{color:#f00}
.fw-b{font-weight:bold}
.fs-10{font-size:1rem} .fs-12{font-size:1.2rem} .fs-13{font-size:1.3rem} .fs-14{font-size:1.4rem} .fs-15{font-size:1.5rem} .fs-16{font-size:1.6rem} .fs-18{font-size:1.8rem} .fs-20{font-size:2rem}

.ta-l{text-align:left!important} .ta-c{text-align:center!important} .ta-r{text-align:right!important}
@media (max-width:768px){ .sp-ta-l{text-align:left!important} .sp-ta-c{text-align:center!important} .sp-ta-r{text-align:right!important} }

[class*="m-0"]{margin:0}
[class*="mt-0"]{margin-top:0} [class*="mt-10px"]{margin-top:10px} [class*="mt-20px"]{margin-top:20px} [class*="mt-30px"]{margin-top:30px} [class*="mt-40px"]{margin-top:40px} [class*="mt-50px"]{margin-top:50px}
[class*="mr-0"]{margin-right:0} [class*="mr-5px"]{margin-right:5px} [class*="mr-10px"]{margin-right:10px} [class*="mr-20px"]{margin-right:20px} [class*="mr-auto"]{margin-right:auto}
[class*="mb-0"]{margin-bottom:0} [class*="mb-10px"]{margin-bottom:10px} [class*="mb-20px"]{margin-bottom:20px} [class*="mb-30px"]{margin-bottom:30px} [class*="mb-40px"]{margin-bottom:40px} [class*="mb-50px"]{margin-bottom:50px}
[class*="ml-0"]{margin-left:0} [class*="ml-5px"]{margin-left:5px} [class*="ml-10px"]{margin-left:10px} [class*="ml-20px"]{margin-left:20px} [class*="ml-auto"]{margin-left:auto}
@media(min-width:769px) {
[class*="sp-mt"]{margin-top:0}
[class*="sp-mr"]{margin-right:0}
[class*="sp-mb"]{margin-bottom:0}
[class*="sp-ml"]{margin-left:0}
}
@media(max-width:768px) {
[class*="pc-mt"]{margin-top:0}
[class*="pc-mr"]{margin-right:0}
[class*="pc-mb"]{margin-bottom:0}
[class*="pc-ml"]{margin-left:0}
}

.table-c { display:table; margin-left:auto; margin-right:auto; }
