@charset "UTF-8";
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box; }

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin: 0; }

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role="list"],
ol[role="list"] {
  list-style: none; }

/* Set core root defaults */
html {
  scroll-behavior: smooth; }

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
  color: #1a1a1a;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif"; }
  body.art2021 {
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif; }

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto; }

/* Make images easier to work with */
img,
picture {
  max-width: 100%;
  display: block; }

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit; }

/* Remove all animations and transitions for people that prefer not to see them */
/*
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
*/
/* var TextSize */
/* var Breakpoints */
a.ico-after-pdf::after {
  display: inline-block;
  content: url("/welfare/img/charity/shikishi2023/design/ico.pdf.png");
  height: 18px;
  vertical-align: text-bottom;
  margin-left: .4em; }
  p a.ico-after-pdf::after {
    vertical-align: revert; }

.alert-radius {
  border-radius: 20px;
  padding: 22px 40px; }
  @media screen and (max-width: 768px) {
    .alert-radius {
      padding: 18px 20px; } }
  @media screen and (max-width: 575px) {
    .alert-radius {
      border-radius: 12px;
      padding: 10px 12px; } }

.wrap {
  position: relative;
  padding-top: 57px; }
  @media screen and (max-width: 575px) {
    .wrap {
      padding-top: 0; } }

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
  background-color: #b31212; }
  @media screen and (max-width: 575px) {
    .header {
      display: none; } }
  .header__inner {
    max-width: 1200px;
    display: flex;
    justify-content: space-between;
    padding: 20px 15px 16px;
    margin: auto; }
  .header .brand {
    font-size: 0.875rem;
    line-height: 1; }
    .header .brand a {
      color: #fff; }
      .header .brand a:hover {
        text-decoration: none; }
  .header .meta {
    line-height: 1; }

.section__inner {
  max-width: 1200px;
  padding: 20px 15px;
  margin: auto; }
  @media screen and (max-width: 768px) {
    .section__inner {
      padding: 14px 4%; } }
.section-header {
  text-align: center; }
.section-confirm .section__inner {
  max-width: 100%; }
.section-confirm .confirm-box {
  width: 100%;
  z-index: 1;
  background-color: rgba(255, 255, 255, 0.9);
  border-top: transparent 1px solid; }
  .section-confirm .confirm-box.fixed {
    position: fixed;
    right: 0;
    bottom: 0;
    border-top: #eee 1px solid; }
.section-slide {
  background-color: #b31212; }
  .section-slide .section__inner {
    width: 100%;
    max-width: 100%;
    padding: 40px 0 30px; }
    .section-slide .section__inner + p {
      text-align: center;
      color: #fff;
      margin: 0 auto;
      padding-bottom: 30px; }
      @media screen and (max-width: 768px) {
        .section-slide .section__inner + p {
          margin: 0 auto;
          padding: 30px; } }
    @media screen and (max-width: 768px) {
      .section-slide .section__inner {
        padding-bottom: 15px; } }
    @media screen and (max-width: 575px) {
      .section-slide .section__inner {
        font-size: 0.75rem; } }

.footer .page-top {
  text-align: center;
  padding: 50px 1em 40px; }
  @media screen and (max-width: 575px) {
    .footer .page-top {
      padding: 80px 0 20px; } }
  .footer .page-top .gototop {
    display: inline-block;
    font-size: 1rem;
    line-height: 1;
    color: #1a1a1a;
    position: relative;
    padding-top: 26px;
    font-size: 1rem; }
    .footer .page-top .gototop::before, .footer .page-top .gototop::after {
      content: "";
      position: absolute;
      left: 50%;
      top: 0;
      display: inline-block;
      width: 12px;
      height: 0;
      border-top: 1px #1a1a1a solid; }
    .footer .page-top .gototop::before {
      transform: translateX(-11.5px) rotate(-30deg); }
    .footer .page-top .gototop::after {
      transform: translateX(-0.5px) rotate(30deg); }
.footer__inner {
  padding: 20px 15px 40px;
  margin: auto;
  text-align: center; }
.footer .c-name {
  display: inline-block;
  font-size: 0.938rem;
  font-weight: bold;
  line-height: 1.2;
  color: #595656;
  margin-top: 30px; }
  .footer .c-name::before {
    display: inline-block;
    content: url("/welfare/img/charity/shikishi2023/design/logo.s.png");
    vertical-align: middle;
    margin-right: .8em; }
.footer .tel {
  font-size: 0.875rem;
  line-height: 1.2; }
.footer .copyright {
  font-size: 0.75rem;
  line-height: 1.8; }

.searchBox-body {
  text-align: center;
  padding: 10px; }
.searchBox-footer {
  text-align: center;
  padding: 10px; }

.searchInfo {
  margin: auto; }

.itemlist ul {
  display: flex;
  flex-wrap: wrap;
  padding: 0;
  margin: 0;
  list-style: none; }
.itemlist li {
  width: 22%;
  padding: 0;
  margin-right: 4%;
  margin-bottom: 30px; }
  @media screen and (max-width: 768px) {
    .itemlist li {
      width: 30%;
      margin-right: 5%; } }
  @media screen and (max-width: 575px) {
    .itemlist li {
      width: 47%;
      margin-right: 6%; } }
  @media screen and (max-width: 575px) {
    .itemlist li:nth-child(2n) {
      margin-right: 0; } }
@media screen and (max-width: 768px) and (min-width: 576px) {
  .itemlist li:nth-child(3n) {
    margin-right: 0; } }

  @media screen and (min-width: 769px) {
    .itemlist li:nth-child(4n) {
      margin-right: 0; } }
.itemlist .card-img-top a {
  height: 164px;
  background-attachment: local;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain; }
  @media screen and (max-width: 768px) {
    .itemlist .card-img-top a {
      height: 24vw; } }
  @media screen and (max-width: 575px) {
    .itemlist .card-img-top a {
      height: 36vw; } }
body.list--ranking .itemlist li:nth-child(n+21) {
  display: none; }

.media-img-top img,
.card-img-top img {
  width: 100%;
  height: auto; }
.media.checked,
.card.checked {
  background-color: #ffebeb; }

.selectedlist {
  padding: 0;
  list-style: none;
  position: relative; }
  .selectedlist::after {
    content: "";
    width: 100%;
    height: 1px;
    background-color: #1a1a1a;
    position: absolute;
    right: 0;
    bottom: 0; }
  .selectedlist li {
    padding: 38px 38px;
    border-top: 1px #1a1a1a solid; }
    @media screen and (max-width: 768px) {
      .selectedlist li {
        padding: 15px 20px; } }
    @media screen and (max-width: 575px) {
      .selectedlist li {
        padding: 15px 10px; } }
  .selectedlist .media-footer .close {
    display: block;
    width: 38px;
    height: 38px;
    position: relative; }
    .selectedlist .media-footer .close span {
      display: none; }
    .selectedlist .media-footer .close::before, .selectedlist .media-footer .close::after {
      content: "";
      display: inline-block;
      width: 1px;
      height: 42px;
      background-color: #1a1a1a;
      position: absolute;
      left: 50%;
      top: 50%; }
    .selectedlist .media-footer .close::before {
      transform: translate(-50%, -50%) rotate(45deg); }
    .selectedlist .media-footer .close::after {
      transform: translate(-50%, -50%) rotate(-45deg); }

.cautionlist {
  padding-left: 0; }
  .cautionlist li {
    list-style: none;
    padding-left: 2em;
    position: relative;
    font-size: 0.875rem; }
    .cautionlist li::before {
      content: '※';
      position: absolute;
      left: 0;
      top: 0; }

.submenu {
  display: inline-flex;
  list-style: none;
  padding: 0;
  margin-bottom: 0; }
  .submenu li {
    font-size: 0.75rem;
    color: #fff;
    line-height: 21px;
    margin-left: 10px;
    vertical-align: middle; }
    .submenu li::first-child {
      margin-left: 0; }
    .submenu li a {
      color: #fff; }
      .submenu li a .fab, .submenu li a .fa-brands {
        font-size: 1.125rem; }
    @media screen and (max-width: 575px) {
      .header .submenu li:not(.link-writer) {
        display: none; } }
  .submenu .link-writer {
    margin-left: 40px; }
    @media screen and (max-width: 575px) {
      .submenu .link-writer {
        margin-left: 0; } }

.btn-sns {
  display: inline-block;
  text-align: center;
  font-size: 1rem;
  line-height: 16px;
  width: 20px;
  height: 16px;
  color: #1a1a1a; }

.table th {
  font-weight: normal;
  background-color: #f5f5f5; }

.media .name {
  font-size: 0.875rem;
  line-height: 1.2; }
.media .title {
  font-size: 0.875rem;
  line-height: 1.2;
  margin-top: 0.75rem; }
.media .type {
  font-size: 0.875rem;
  line-height: 1.2;
  margin-top: 0.75rem; }
.media .price {
  font-size: 0.875rem;
  line-height: 1.2;
  margin-top: 0.75rem; }

.slideshow {
  display: flex;
  align-items: center;
  overflow: hidden; }
  .slideshow__inner {
    display: flex;
    transform: translateX(0);
    animation: loop-slide 40s infinite linear 1s both;
    list-style: none;
    padding: 0;
    margin: 0 !important; }
  .slideshow .content {
    width: auto;
    height: 365px;
    margin-left: 5px;
    margin-right: 5px; }
    @media screen and (max-width: 768px) {
      .slideshow .content {
        height: calc( 22vw * 38 / 31 + 25px ); } }
    @media screen and (max-width: 575px) {
      .slideshow .content {
        height: calc( 40vw * 38 / 31 + 25px ); } }
    .slideshow .content figure {
      width: auto;
      height: 365px;
      padding-bottom: 30px;
      position: relative; }
      @media screen and (max-width: 768px) {
        .slideshow .content figure {
          height: calc( 22vw * 38 / 31 + 25px ); } }
      @media screen and (max-width: 575px) {
        .slideshow .content figure {
          height: calc( 40vw * 38 / 31 + 25px ); } }
      .slideshow .content figure img {
        max-width: none;
        width: auto;
        height: 340px; }
        @media screen and (max-width: 768px) {
          .slideshow .content figure img {
            height: calc( 22vw * 38 / 31 ); } }
        @media screen and (max-width: 575px) {
          .slideshow .content figure img {
            height: calc( 40vw * 38 / 31 ); } }
    .slideshow .content figcaption {
      text-align: center;
      font-size: 0.75rem;
      color: #fff;
      position: absolute;
      width: 100%;
      bottom: 0;
      right: 0; }
      @media screen and (max-width: 768px) {
        .slideshow .content figcaption {
          font-size: 0.625rem;
          line-height: 1.2; } }

@keyframes loop-slide {
  from {
    transform: translateX(0); }
  to {
    transform: translateX(-100%); } }
.error {
  font-size: 1rem;
  line-height: 2;
  font-weight: bold;
  text-align: center; }
  @media screen and (max-width: 991px) {
    .error {
      text-align: left; } }
  @media screen and (max-width: 768px) {
    .error {
      font-size: 0.875rem;
      line-height: 2; } }
  .error-danger {
    color: #cc2929; }

.modal .error {
  padding: 40px 15px;
  border-top: 1px solid #1a1a1a; }
  .modal .error.mod--bb {
    border-bottom: 1px solid #1a1a1a; }
.modal .selectedlist + .error {
  border-top: none; }

.pswp__caption__center {
  text-align: center; }

/*
 *
 *
 *
 **/
#itemlist #itemsAll, #itemlist #itemsWajima, #itemlistWajima #itemsAll,
#itemlistWajima #itemsWajima {
  display: flex; }
  .wrap.pop #itemlist #itemsAll,
  .wrap.pop #itemlist #itemsWajima,
  .wrap.pop #itemlistWajima #itemsAll,
  .wrap.pop
  #itemlistWajima #itemsWajima {
    display: none; }
#itemlist #itemsPopular, #itemlist #itemsPopularWajima, #itemlistWajima #itemsPopular,
#itemlistWajima #itemsPopularWajima {
  display: none; }
  .wrap.pop #itemlist #itemsPopular,
  .wrap.pop #itemlist #itemsPopularWajima,
  .wrap.pop #itemlistWajima #itemsPopular,
  .wrap.pop
  #itemlistWajima #itemsPopularWajima {
    display: block; }

body.shikishi {
  /**/
  /**/
  /**/
  /**/
  /**/ }
  body.shikishi img {
    pointer-events: none;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-touch-callout: none;
    -moz-user-select: none;
    touch-callout: none;
    user-select: none; }
  body.shikishi .font-en {
    font-family: 'Aldrich', sans-serif;
    letter-spacing: 2px; }
  body.shikishi .header {
    /*border-bottom: 1px #CCC solid;*/
    color: #fff; }
  body.shikishi .section-header {
    background-image: url("/welfare/img/charity/shikishi2025/design/header-bg.png");
    background-attachment: local;
    background-position: center 0;
    background-repeat: no-repeat;
    background-size: cover;
    width: 100%;
    margin: auto; }
    @media screen and (max-width: 575px) {
      body.shikishi .section-header {
        background-image: url("/welfare/img/charity/shikishi2025/design/header-bg-sp.png");
        background-position: center 0px;
        background-size: cover; } }
    body.shikishi .section-header .section__inner {
      text-align: center;
      padding: 80px 0; }
      @media screen and (max-width: 991px) {
        body.shikishi .section-header .section__inner {
          padding: 60px 0; } }
      @media screen and (max-width: 575px) {
        body.shikishi .section-header .section__inner {
          padding: 40px 0 30px; } }
    body.shikishi .section-header .contents-header {
      /*background-color: #FFF;*/
      border-radius: 20px 30px;
      padding: 0;
      max-width: 980px;
      margin-left: auto;
      margin-right: auto; }
    body.shikishi .section-header .title-row {
      display: flex;
      justify-content: space-around;
      align-items: flex-start; }
      @media screen and (max-width: 991px) {
        body.shikishi .section-header .title-row {
          align-items: stretch; } }
    body.shikishi .section-header .h1 {
      line-height: 0; }
      body.shikishi .section-header .h1 a {
        display: block;
        margin: 0;
        padding: 0;
        color: #1a1a1a; }
        body.shikishi .section-header .h1 a:hover {
          text-decoration: none; }
      body.shikishi .section-header .h1 .en {
        display: block;
        font-size: 1.125rem;
        line-height: 1.125rem;
        margin-bottom: 1em; }
        @media screen and (max-width: 575px) {
          body.shikishi .section-header .h1 .en {
            font-size: 0.875rem; } }
      body.shikishi .section-header .h1 span:not(.en) {
        font-size: 2.25rem;
        line-height: 1.6;
        font-weight: bold; }
        @media screen and (max-width: 768px) {
          body.shikishi .section-header .h1 span:not(.en) {
            font-size: 1.5rem;
            line-height: 1.4; } }
        @media screen and (max-width: 575px) {
          body.shikishi .section-header .h1 span:not(.en) {
            font-size: 1.125rem;
            line-height: 1.6; } }
    body.shikishi .section-header .term {
      margin-top: 0.5em;
      line-height: 0; }
      @media screen and (max-width: 575px) {
        body.shikishi .section-header .term {
          margin-top: .5em; } }
      body.shikishi .section-header .term span {
        color: #cc2929;
        font-weight: bold;
        font-size: 1.5rem;
        line-height: 1.5rem;
        display: inline-block; }
        @media screen and (max-width: 575px) {
          body.shikishi .section-header .term span {
            font-size: 1rem;
            line-height: 1.25rem; } }
        body.shikishi .section-header .term span em {
          font-size: 1.875rem;
          line-height: 1.875rem;
          font-style: normal; }
          @media screen and (max-width: 575px) {
            body.shikishi .section-header .term span em {
              font-size: 1.25rem;
              line-height: 1.25rem; } }
        body.shikishi .section-header .term span small {
          font-size: 1.125rem;
          line-height: 1.5rem;
          font-weight: bold; }
          @media screen and (max-width: 575px) {
            body.shikishi .section-header .term span small {
              font-size: 0.875rem;
              line-height: 1.5rem; } }
      body.shikishi .section-header .term i {
        display: inline-block;
        text-indent: -9999px;
        overflow: hidden;
        outline: none;
        width: 18px;
        height: 1px;
        background-color: #cc2929;
        vertical-align: middle;
        margin-left: .25em;
        margin-right: .25em; }
  body.shikishi .section-search .section__inner {
    text-align: center; }
  body.shikishi .section-list .section__inner {
    max-width: 1110px;
    margin-left: auto;
    margin-right: auto; }
    body.shikishi .section-list .section__inner #shikishi::before, body.shikishi .section-list .section__inner #wajima::before {
      content: "";
      display: block;
      height: 60px;
      /* 調整したい高さ（固定ヘッダーの高さ） */
      margin-top: -60px;
      /* heightと同じ分のネガティブマージン */
      visibility: hidden; }
      @media screen and (max-width: 575px) {
        body.shikishi .section-list .section__inner #shikishi::before, body.shikishi .section-list .section__inner #wajima::before {
          height: 10px;
          /* 調整したい高さ（固定ヘッダーの高さ） */
          margin-top: -10px;
          /* heightと同じ分のネガティブマージン */ } }
    body.shikishi .section-list .section__inner h2 {
      color: #fff;
      text-align: center;
      padding: 10px 20px;
      background-color: #b31212;
      margin: 60px auto;
      border-radius: 20px; }
      @media screen and (max-width: 575px) {
        body.shikishi .section-list .section__inner h2 {
          font-size: 1.5rem;
          margin: 40px auto; } }
  body.shikishi .section-list .text-end {
    margin-bottom: 20px; }
  body.shikishi .section-confirm .section__inner {
    padding-top: 20px; }
    @media screen and (max-width: 575px) {
      body.shikishi .section-confirm .section__inner {
        padding: 20px 4%; } }
    body.shikishi .section-confirm .section__inner .confirm-box {
      padding: 20px 15px 10px;
      z-index: 0; }
      @media screen and (max-width: 575px) {
        body.shikishi .section-confirm .section__inner .confirm-box {
          padding-bottom: 20px; } }
  body.shikishi .section-about {
    background-image: url("/welfare/img/charity/shikishi2025/design/contents-bg.png");
    background-repeat: repeat;
    background-attachment: local;
    background-position: center top;
    background-size: 200px; }
    @media screen and (max-width: 575px) {
      body.shikishi .section-about {
        background-size: 100px; } }
    body.shikishi .section-about .section__inner {
      max-width: 1000px;
      margin-left: auto;
      margin-right: auto;
      padding-top: 60px;
      padding-bottom: 40px; }
      @media screen and (max-width: 768px) {
        body.shikishi .section-about .section__inner {
          padding: 40px 4%; } }
      @media screen and (max-width: 575px) {
        body.shikishi .section-about .section__inner {
          padding: 40px 4%; } }
    body.shikishi .section-about .text-end {
      margin-bottom: 20px; }
  body.shikishi .section-anchorLink {
    background-color: #b31212;
    margin-bottom: 20px; }
    @media screen and (max-width: 575px) {
      body.shikishi .section-anchorLink {
        margin: 0 auto 20px; } }
    body.shikishi .section-anchorLink .section__inner {
      padding: 30px 15px; }
  body.shikishi .section a {
    color: #1a1a1a; }
  body.shikishi .section .h2 {
    text-align: center;
    font-size: 1.875rem;
    line-height: 1.6;
    font-weight: bold;
    margin-bottom: 30px; }
    @media screen and (max-width: 768px) {
      body.shikishi .section .h2 {
        font-size: 1.75rem; } }
    @media screen and (max-width: 575px) {
      body.shikishi .section .h2 {
        font-size: 1.375rem; } }
  body.shikishi .section .h3 {
    font-size: 1.25rem;
    line-height: 1.8;
    font-weight: bold;
    margin-top: 40px;
    margin-bottom: 30px; }
    @media screen and (max-width: 575px) {
      body.shikishi .section .h3 {
        font-size: 1.125rem;
        line-height: 1.8;
        margin-top: 20px;
        margin-bottom: 15px; } }
  body.shikishi .section p, body.shikishi .section li, body.shikishi .section th, body.shikishi .section td, body.shikishi .section dd {
    font-size: 0.875rem;
    line-height: 2; }
    @media screen and (max-width: 768px) {
      body.shikishi .section p, body.shikishi .section li, body.shikishi .section th, body.shikishi .section td, body.shikishi .section dd {
        line-height: 2; } }
  body.shikishi .section .credit {
    font-size: 0.875rem;
    font-weight: bold;
    margin-top: 20px; }
    @media screen and (max-width: 575px) {
      body.shikishi .section .credit {
        font-size: 0.75rem; } }
  body.shikishi .section .text-end {
    color: #cc2929;
    font-weight: bold;
    font-size: 1.25rem;
    padding-left: 0; }
  body.shikishi .section ul {
    margin-top: 24px; }
    @media screen and (max-width: 575px) {
      body.shikishi .section ul {
        margin-top: 15px; } }
  body.shikishi .section ul.caution {
    margin-top: 1.2em; }
    body.shikishi .section ul.caution li {
      font-size: 0.75rem;
      line-height: 1.8;
      list-style: none;
      position: relative; }
      body.shikishi .section ul.caution li::before {
        content: "※";
        position: absolute;
        left: -1.4em;
        top: 0; }
  body.shikishi .searchBox {
    max-width: 1080px;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid #ccc;
    background-color: #fff;
    margin: 0 auto; }
    body.shikishi .searchBox-body {
      overflow: hidden;
      /*background-image: url("/welfare/img/charity/shikishi2025/design/contents-bg.png");
      background-repeat: repeat;
      background-attachment: local;
      background-position: center top;*/
      display: flex;
      justify-content: space-around;
      padding: 40px 15px 30px; }
      @media screen and (max-width: 768px) {
        body.shikishi .searchBox-body {
          flex-direction: column; } }
      body.shikishi .searchBox-body a {
        vertical-align: bottom; }
    body.shikishi .searchBox-footer {
      overflow: hidden;
      background-color: #e6e6e6;
      padding: 15px; }
    body.shikishi .searchBox .searchInfo {
      font-size: 0.875rem;
      line-height: 1.2; }
    body.shikishi .searchBox .btn-go {
      color: #CCC;
      border-color: #CCC; }
      body.shikishi .searchBox .btn-go:hover, body.shikishi .searchBox .btn-go.current {
        color: #1a1a1a;
        border-color: #1a1a1a; }
  body.shikishi .anchorLink {
    max-width: 1080px;
    margin: 10px auto 0; }
    body.shikishi .anchorLink-body {
      display: flex;
      justify-content: space-around;
      padding: 0; }
      @media screen and (max-width: 768px) {
        body.shikishi .anchorLink-body {
          flex-direction: column; } }
      body.shikishi .anchorLink-body a {
        vertical-align: bottom; }
  body.shikishi .board {
    background-color: #FFF;
    border-radius: 20px;
    padding: 46px 40px; }
    @media screen and (max-width: 768px) {
      body.shikishi .board {
        padding: 40px 20px; } }
    @media screen and (max-width: 575px) {
      body.shikishi .board {
        padding: 40px 15px; } }
    body.shikishi .board-white {
      background-color: #FFF; }
      body.shikishi .board-white.message {
        background-color: #ffebeb; }
    body.shikishi .board .h3 {
      font-size: 1.125rem;
      line-height: 1.6; }
      body.shikishi .board .h3::before {
        content: "●";
        display: inline-block;
        margin-right: .5em; }
    body.shikishi .board ul {
      padding-left: 40px; }
      @media screen and (max-width: 768px) {
        body.shikishi .board ul {
          padding-left: 20px;
          line-height: 1.8; } }
    body.shikishi .board p {
      padding-left: 20px; }
      @media screen and (max-width: 768px) {
        body.shikishi .board p {
          padding-left: 20px;
          line-height: 1.8; } }
    body.shikishi .board .text-end {
      margin-top: 20px; }
  body.shikishi .card {
    border-radius: 20px;
    overflow: hidden; }
    body.shikishi .card .name {
      font-size: 0.875rem;
      line-height: 1.2; }
    body.shikishi .card .title {
      font-size: 0.875rem;
      line-height: 1.2;
      margin-top: 1em; }
    body.shikishi .card .price {
      font-size: 0.75rem;
      line-height: 1.2;
      margin-top: 1em; }
    body.shikishi .card-footer {
      background-color: transparent;
      border-top: none;
      position: relative; }
      body.shikishi .card-footer::before {
        content: "";
        display: inline-block;
        width: calc( 100% - 2rem );
        max-width: 100%;
        height: 0;
        position: absolute;
        left: 50%;
        top: 0;
        transform: translateX(-50%);
        border-top: 1px #CCC dotted; }
      body.shikishi .card-footer span {
        font-size: 0.875rem;
        line-height: 1.2; }
  body.shikishi .footer .page-top .gototop {
    font-family: 'Aldrich', sans-serif;
    letter-spacing: 2px; }
  body.shikishi .footer__inner {
    position: relative;
    padding-top: 100px;
    /*&::before {
      display: block;
      content: "";
      background-image: url("/welfare/img/charity/shikishi2025/design/line_footer.png");
      background-attachment: local;
      background-repeat: repeat-x;
      background-size: 14px;
      overflow: hidden;
      //
      position: absolute;
      left: 50%;
      top: 0;
      width: 100%;
      height: 20px;
      transform: translateX(-50%);
    }*/ }
    @media screen and (max-width: 575px) {
      body.shikishi .footer__inner {
        padding-top: 120px; } }
    body.shikishi .footer__inner .text-center li {
      color: #1a1a1a; }
      body.shikishi .footer__inner .text-center li a {
        color: #1a1a1a; }
      body.shikishi .footer__inner .text-center li:first-child {
        margin-left: 0; }
  body.shikishi .btn-go {
    min-width: 300px;
    padding: 12px 20px;
    border-radius: 20px;
    border-color: #1a1a1a;
    background-color: #FFF;
    border-bottom-width: 4px;
    margin-bottom: 10px;
    transition: background .3s ease; }
    @media screen and (min-width: 769px) {
      body.shikishi .btn-go:hover {
        background-color: #f5f5f5; } }
    @media screen and (max-width: 768px) {
      body.shikishi .btn-go {
        padding: 12px 15px;
        margin-bottom: 30px; }
        body.shikishi .btn-go:last-child {
          margin-bottom: 0; } }
    @media screen and (max-width: 575px) {
      body.shikishi .btn-go {
        min-width: auto;
        max-width: 90%;
        width: 90%; } }
  body.shikishi .modal-content {
    border-radius: 20px;
    border-width: 3px;
    border-color: #CCC; }
  body.shikishi .modal-header.mod--charity {
    display: flex;
    justify-content: center;
    align-items: stretch;
    padding-top: 60px;
    padding-bottom: 40px;
    border-bottom: none; }
    @media screen and (max-width: 991px) {
      body.shikishi .modal-header.mod--charity {
        align-items: stretch;
        padding-top: 30px;
        padding-bottom: 20px; } }
    @media screen and (max-width: 575px) {
      body.shikishi .modal-header.mod--charity {
        padding-top: 15px;
        padding-bottom: 10px; } }
    body.shikishi .modal-header.mod--charity::before {
      content: url("/welfare/img/charity/shikishi2025/design/head-side-left.png");
      margin-right: 10%; }
      @media screen and (max-width: 991px) {
        body.shikishi .modal-header.mod--charity::before {
          width: 15%;
          content: "";
          background-image: url("/welfare/img/charity/shikishi2025/design/head-side-left.png");
          background-size: contain;
          background-repeat: no-repeat;
          background-position: right center; } }
      @media screen and (max-width: 768px) {
        body.shikishi .modal-header.mod--charity::before {
          margin-right: 5%; } }
    body.shikishi .modal-header.mod--charity::after {
      content: url("/welfare/img/charity/shikishi2025/design/head-side-right.png");
      margin-left: 10%; }
      @media screen and (max-width: 991px) {
        body.shikishi .modal-header.mod--charity::after {
          width: 15%;
          content: "";
          background-image: url("/welfare/img/charity/shikishi2025/design/head-side-right.png");
          background-size: contain;
          background-repeat: no-repeat;
          background-position: left center; } }
      @media screen and (max-width: 768px) {
        body.shikishi .modal-header.mod--charity::after {
          margin-left: 5%; } }
    body.shikishi .modal-header.mod--charity .close {
      position: absolute;
      right: 30px;
      top: 30px;
      opacity: 1;
      width: 30px;
      height: 30px;
      padding: 0;
      line-height: 30px;
      text-align: center;
      border-radius: 50%;
      background-color: #1a1a1a;
      transition: opacity .3s ease; }
      body.shikishi .modal-header.mod--charity .close span {
        color: #FFF; }
      @media screen and (min-width: 769px) {
        body.shikishi .modal-header.mod--charity .close:hover {
          opacity: .5; } }
  body.shikishi .modal-title {
    font-size: 1.875rem;
    line-height: 1.2;
    margin: auto 30px;
    display: inline-block; }
    @media screen and (max-width: 768px) {
      body.shikishi .modal-title {
        font-size: 1.5rem;
        line-height: 1.2;
        margin: 15px 0; } }
    @media screen and (max-width: 575px) {
      body.shikishi .modal-title {
        font-size: 1.375rem;
        line-height: 1.2; } }
  body.shikishi .modal-body {
    padding-left: 40px;
    padding-right: 40px; }
    @media screen and (max-width: 768px) {
      body.shikishi .modal-body {
        padding-left: 20px;
        padding-right: 20px; } }
    @media screen and (max-width: 575px) {
      body.shikishi .modal-body {
        padding-left: 10px;
        padding-right: 10px; } }
  body.shikishi .selectedlist .media figure {
    width: 130px;
    text-align: center; }
    body.shikishi .selectedlist .media figure img {
      max-width: 100%;
      height: auto; }
    @media screen and (max-width: 575px) {
      body.shikishi .selectedlist .media figure {
        width: 100px; } }
  body.shikishi .pswp__counter {
    font-size: 1.5rem;
    width: 100%;
    text-align: center; }
  body.shikishi .pswp__button--arrow--left::before, body.shikishi .pswp__button--arrow--right::before {
    background-size: contain;
    height: 40px;
    width: 40px; }
  body.shikishi .pswp__button--arrow--left::before {
    left: 10px; }
  body.shikishi .pswp__button--arrow--right::before {
    right: 10px; }
  body.shikishi .pswp__caption__center {
    max-width: 500px; }
    body.shikishi .pswp__caption__center .attention {
      margin-top: 5px;
      margin-left: auto;
      margin-right: auto;
      display: inline-block;
      font-size: 10px;
      line-height: 1.2;
      text-align: left; }
  body.shikishi .background {
    background-image: url("/welfare/img/charity/shikishi2025/design/contents-bg.png");
    background-repeat: repeat;
    background-attachment: local;
    background-position: center top;
    background-size: 200px; }
    @media screen and (max-width: 575px) {
      body.shikishi .background {
        background-size: 100px; } }
  body.shikishi .pagetop {
    display: none;
    position: fixed; }
  body.shikishi .pagetop a {
    display: flex;
    justify-content: center;
    align-items: center;
    position: fixed;
    right: 30px;
    bottom: 90px;
    width: 70px;
    height: 70px;
    border: 1px solid #1a1a1a;
    background-color: #1a1a1a;
    border-radius: 100%;
    cursor: pointer;
    transform: translateY(50px);
    z-index: 10; }
    body.shikishi .pagetop a::after {
      font-family: "Font Awesome 5 Free";
      content: "\f062";
      color: #fff;
      font-size: 2rem;
      display: inline-block;
      font-weight: 700; }
      @media screen and (max-width: 575px) {
        body.shikishi .pagetop a::after {
          font-size: 1.5rem; } }
    @media screen and (max-width: 575px) {
      body.shikishi .pagetop a {
        width: 50px;
        height: 50px;
        right: 10px;
        bottom: 160px; } }
  body.shikishi .pagetop a:hover {
    opacity: .8;
    text-decoration: none; }
  body.shikishi.top .footer__inner {
    padding-top: 40px; }
  @media screen and (max-width: 575px) {
    body.shikishi.top .pagetop a {
      bottom: 60px; } }
  body.shikishi .prof .name {
    font-size: 1.125rem;
    margin-bottom: 20px;
    padding-left: 0; }
    body.shikishi .prof .name span {
      font-size: 0.875rem; }
    body.shikishi .prof .name + div {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      @media screen and (max-width: 575px) {
        body.shikishi .prof .name + div {
          flex-direction: column-reverse; } }
      body.shikishi .prof .name + div div {
        width: 75%; }
        @media screen and (max-width: 575px) {
          body.shikishi .prof .name + div div {
            width: 100%; } }
        body.shikishi .prof .name + div div p {
          margin-bottom: 20px;
          padding-left: 0; }
          body.shikishi .prof .name + div div p:last-child {
            margin-bottom: 0; }
      body.shikishi .prof .name + div figure {
        width: 20%; }
        @media screen and (max-width: 575px) {
          body.shikishi .prof .name + div figure {
            width: 40%;
            margin: 0 auto 20px; } }
  body.shikishi .icon-x {
    width: 18px; }
  body.shikishi .submenu .icon-x {
    filter: invert(100%) sepia(0%) saturate(7487%) hue-rotate(334deg) brightness(103%) contrast(103%); }
  body.shikishi .footer .icon-x {
    filter: invert(4%) sepia(1%) saturate(183%) hue-rotate(314deg) brightness(89%) contrast(85%); }

/*@import 'art2022'*/

/*# sourceMappingURL=charity.css.map */
