@charset "UTF-8";
/* 変数
-------------------------------- */
@media screen and (max-width: 820px) {
  /* mixin
  -------------------------------- */
  body {
    min-width: inherit;
  }

  /* common
  -------------------------------- */
  .inner {
    max-width: 700px;
    padding: 0;
    margin: 0 auto;
  }

  /* header
  -------------------------------- */
  #header {
    border-top: solid 5px #6e327d;
    padding-bottom: 0;
  }
  #header .inner-menu {
    border-top: solid 2px #d7bdd8;
    border-bottom: solid 1px #d7bdd8;
    background-color: #FFF;
  }
  #header .menu {
    background: url(./images/menu-bg-line.gif) no-repeat left center;
    background-size: 1px 20px;
    /* max-width: 700px; */
    padding: 0;
    margin: 0 auto;
  }
  #header .menu li a {
    display: block;
    padding: 10px 11px;
    font-size: 15px;
  }
  #header .menu li:last-child a {
    padding-left: 14px;
    padding-right: 12px;
  }
  #header .sub-menu {
    right: 70px;
  }
  #header .sub-menu li.lang a:hover {
    background-color: #6e327d;
  }

  #header .multilingual {
    right: 45px;
  }

  /* content
  -------------------------------- */
  #content a:hover img {
    opacity: 0.6;
    filter: alpha(opacity=60);
  }
  #content #cover img {
    width: 100%;
    max-width: 100%;
  }
  #content .inner {
    max-width: 700px;
    padding: 0;
    margin: 0 auto;
    width: 700px;
  }
  #content article .col-four {
    margin: -30px 0 0 -3.2%;
    padding: 0;
    list-style: none;
    overflow: hidden;
  }
  #content article .col-four .cols {
    margin-top: 30px;
    padding-left: 3.2%;
    display: table-cell;
    float: left;
    width: 30%;
    vertical-align: top;
  }
  #content article .col-four .cols figure {
    margin-bottom: 15px;
    padding: 0;
    vertical-align: top;
  }
  #content article .col-four .cols figure img {
    vertical-align: top;
    width: 100%;
    max-width: 100%;
  }
  #content article .col-four .cols figure figcaption {
    margin-top: 10px;
  }
  #content article .col-four .cols h3 {
    margin-bottom: 5px;
  }
  #content article .col-four .cols ul {
    margin: 0;
    padding: 0;
    list-style: none;
    min-height: 80px;
  }
  #content article .col-four .cols ul li {
    font-size: 12px;
  }
  #content article .col-four .cols:last-child ul {
    min-height: inherit;
  }
  #content article section {
    padding-bottom: 30px;
    overflow: hidden;
  }
  #content article section aside {
    float: left;
    width: 27%;
  }
  #content article section .main {
    float: right;
    width: 70%;
  }
  #content article #content-main section:first-child {
    margin-top: 40px;
  }
  #content article.index #content-main section {
    margin-bottom: 30px;
  }
  #content article.index #content-main section:first-child {
    margin-top: 60px;
  }
  #content article.index #content-main section:last-child {
    margin-bottom: 50px;
  }
  #content article.index h2 {
    margin-bottom: 20px;
    padding-top: 20px;
    border-top: solid 1px #999;
  }
  #content article.index h2 a {
    color: #000;
  }
  #content article.index h2 a:hover {
    color: #999;
  }
  #content article.detail h2 {
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: solid 1px #999;
  }
  #content article.archive .cols {
    cursor: pointer;
    color: #6e327d;
  }
  #content article.archive .cols figure {
    margin: 0;
  }
  #content article.archive .cols:hover {
    opacity: 0.5;
    filter: alpha(opacity=50);
  }
  #content article.archive .GI_TW_expander-inner .fl-right,
  #content article.archive .GI_TW_expander-inner .fl-left {
    margin-bottom: 0;
    vertical-align: bottom;
    display: block;
  }
  #content article.archive .GI_TW_expander-inner .fl-right {
    margin-left: 40px;
  }
  #content article.archive .GI_TW_expander-inner .fl-left {
    margin-right: 40px;
  }
  #content article.archive .GI_TW_expander-inner .txt h3 {
    font-size: 24px;
  }
  #content article.archive .GI_TW_expander-inner .txt a {
    color: #a24cb8;
  }
  #content article.archive .GI_TW_expander-inner .txt a:hover {
    color: #FFF;
  }
  #content article.archive.GITheWall {
    overflow: inherit;
  }
  #content .pagetop {
    float: right;
    display: block;
    width: 40px;
    height: 40px;
    background: url(./images/pagetop.png) no-repeat left bottom;
    background-size: 40px 40px;
    z-index: 1000;
  }
  #content .stickem-container {
    position: relative;
  }
  #content .stickit {
    position: fixed;
    bottom: 76px;
    width: 900px;
  }
  #content .stickit-end {
    bottom: 76px;
    position: absolute;
  }

  /* footer
  -------------------------------- */
  #footer .inner {
    max-width: 700px;
    padding: 0;
    margin: 0 auto;
    padding: 22.5px 0 70px;
  }

#footer .footer_banner_area {
  background: #333333;
  text-align: center;
}

#footer .footer_banner_area .inner {
  max-width: 700px;
  padding: 0;
  margin: 0 auto;
  padding: 35px 0 15px 0;
}

#footer .footer_banner_area li{
  display: block;
  padding: 0px 0 20px 0;
}



  /* home
  -------------------------------- */
  #home #content article .bg.black section {
    max-width: 700px;
    padding: 0;
    margin: 0 auto;
  }
  #home #content article.index #content-main {
    padding-top: 30px;
  }
  #home #content article.index #content-main section {
    margin-bottom: 0;
  }
  #home #content article.index #content-main section:first-child {
    margin-top: 0;
  }
  #home #content article.index #content-main section:last-child {
    margin-bottom: 0;
  }
  #home #content article.index h2 {
    margin-bottom: 20px;
    padding-bottom: 15px;
    padding-top: none;
    border-top: none;
    border-bottom: solid 1px #999;
    font-size: 36px;
  }
  #home #content article.index h2 .title {
    padding-right: 20px;
  }
  #home #content article.index h3 {
    margin: 0 0 20px;
    font-size: 24px;
    font-weight: normal;
  }
  #home #content article.index h4 {
    margin-bottom: 5px;
  }
  #home #content article.index .cat {
    position: absolute;
    top: 45px;
    right: 0;
  }
  #home #content article.index .cat li {
    display: inline-block;
    font-size: 12px;
    color: #999;
  }
  #home #content article.index .col-four {
    margin-bottom: 40px;
  }
  #home #content article.index .news {
    list-style: none;
    margin: 0;
    padding: 0;
    margin-bottom: 30px;
  }
  #home #content article.index .news li {
    border-bottom: solid 1px #999;
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
  #home #content article.index .news li a:hover .date,
  #home #content article.index .news li a:hover .title {
    color: #a24cb8;
  }
  /* #home #content article.index .news li .date,
  #home #content article.index .news li .title {
    color: #FFF;
  } */
  #home #content article.index .news li .title{
    display: block;
    margin-left: 0;
  }
  #home #content article.index .news li .date {
    margin-right: 30px;
    position: relative;
  }
  #home #content article.index .news li .tag {
    margin-right: 30px;
  }
  .news h2 .news_sp_title{
    display: block;
    font-size: 80%;
  }


  /* contact
  -------------------------------- */
  #content article .contact,  #content article .contact tbody, #content article .contact select {
    display: block;
    box-sizing: border-box;
    max-width: 100%;
  }
  #content article .contact tr {
    display: block;
    border-bottom: solid 1px #999;
  }
  #content article .contact td {
    width: 100%;
    display: block;
    border-bottom: none;
  }
  #content article .contact td:not(:last-child) {
    padding-bottom: 0;
  }
  #content article .contact td:last-child{
    padding-top: 10px;
  }
  #content article .contact input, #content article .contact textarea {
    width: 100%;
    box-sizing: border-box;
  }
  #content article .contact p {
    margin-top: 0;
    margin-bottom: 0;
  }

   #content .contact_footer .left, #content .contact_footer .right {
    float: none;
  }

  /* about */
  .video-responsive {
    width: 100%;
  }

  .video-responsive video {
    width: 100%;
    height: 100%;
    aspect-ratio: 450 / 253;
  }

  #content article .agent-list li {
    width: 100%;
    height: auto;
  }

  #content article .agent-list .last:not(:last-of-type) {
    border-bottom: none;
  }

  #production_policy .production_policy_example_inner {
    margin: 0;
   }

  #production_policy .production_policy_example_inner ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  #production_policy .production_policy_example_inner li {
    float: none;
    width: calc(50% - 10px);
    box-sizing: border-box;
    margin: 0;
  }

  #production_policy .production_policy_example_inner li img {
    width: 100%;
  }
}

@media screen and (max-width: 736px) {
  /* mixin
  -------------------------------- */
  body {
    min-width: inherit;
  }

  /* common
  -------------------------------- */
  .inner {
    max-width: 520px;
    padding: 0;
    margin: 0 auto;
  }

  /* header
  -------------------------------- */
  #header {
    border-top: solid 5px #6e327d;
    padding-bottom: 0;
  }
  #header .inner {
    overflow: inherit;
    max-width: 100%;
    padding: 0 0 0 15px;
    margin: 0 auto;
  }
  #header .inner #sp-nav {
    cursor: pointer;
    width: 24px;
    height: 20px;
    background: url(./images/sp-menu.png) no-repeat left center;
    background-size: 24px 20px;
    position: absolute;
    top: 25px;
    right: 20px;
  }
  #header .inner #sp-nav.close {
    background: url(./images/sp-menu-close.png) no-repeat left center;
    background-size: 24px 20px;
  }
  #header .inner-menu {
    border-top: solid 1px #d7bdd8;
    border-bottom: none;
    background-color: #FFF;
    position: absolute;
    top: 60px;
    max-width: 100%;
    width: 100%;
    display: none;
  }
  #header ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  #header #logo {
    margin: 10px 0;
  }
  #header #logo img {
    width: auto;
    height: 34px;
    object-fit: contain;
    vertical-align: bottom;
  }
  #header nav {
    overflow: inherit;
    max-width: 100%;
    width: 100%;
    z-index: 10000;
    background-color: #FFF;
  }
  #header .menu {
    background: none;
  }
  #header .menu li {
    border-bottom: solid 1px #d7bdd8;
    display: block;
    background: none;
    background-size: 1px 20px;
    width: 100%;
  }
  #header .menu li a {
    display: block;
    padding: 10px 28px;
    font-size: 15px;
    text-align: left;
    color: #000;
  }
  #header .menu li a:hover {
    margin-left: -1px;
    border-left: solid 1px #FFF;
    background-color: #6e327d;
    color: #FFF;
  }
  #header .menu li:last-child a {
    padding-left: 33px;
    padding-right: 32px;
  }
  #header .menu li.active a {
    margin-left: -1px;
    border-left: solid 1px #FFF;
    background-color: #6e327d;
    color: #FFF;
  }
  #header .sub-menu {
    border-bottom: solid 1px #d7bdd8;
    position: inherit;
    top: 0;
    right: 0;
    overflow: hidden;
    width: 100%;
  }
  #header .sub-menu li {
    padding: 10px 0;
    float: right;
    display: inline-block;
    width: 25%;
    margin-left: 0;
    text-align: center;
    border-right: solid 1px #d7bdd8;
  }
  #header .sub-menu li a {
    font-size: 15px;
    color: #6e327d;
    line-height: 1em;
  }
  #header .sub-menu li a:hover {
    color: #000;
  }
  #header .sub-menu li.lang {
    border-right: none;
    border-left: solid 1px #d7bdd8;
  }
  #header .sub-menu li.lang a {
    border: solid 1px #FFF;
    padding: 5px 0 0;
    border-radius: 0;
    background-color: #FFF;
    color: #6e327d;
    display: block;
  }
  #header .sub-menu li.lang a:hover {
    border: solid 1px #6e327d;
    background-color: #6e327d;
    color: #FFF;
  }

  #header .multilingual {
    top: 10px;
    right: initial;
    left: 30px;
  }

  #header .menu li.whats_a_planetarium a {
    width: 100%;
    box-sizing: border-box;
  }

  /* content
  -------------------------------- */
  #content a:hover img {
    opacity: 0.6;
    filter: alpha(opacity=60);
  }
  #content .cover_wrapper{
    margin: 0 -25px;
  }
  #content #cover img {
    width: 100%;
    max-width: 100%;
  }
  #content img {
    width: 100%;
    max-width: 100%;
    height: auto;
  }
  #content .inner {
    margin: 0 auto;
    padding: 0 25px;
    width: auto;
  }
  #content article .col-four {
    margin: -30px 0 0 0;
    padding: 0;
    list-style: none;
    overflow: hidden;
  }
  #content article .col-four .cols {
    margin-top: 30px;
    padding-left: 0;
    display: block;
    float: none;
    width: 100%;
    vertical-align: top;
  }
  #content article .col-four .cols figure {
    margin-bottom: 15px;
    padding: 0;
    vertical-align: top;
  }
  #content article .col-four .cols figure img {
    vertical-align: top;
    width: 100%;
    max-width: 100%;
  }
  #content article .col-four .cols figure figcaption {
    margin-top: 10px;
  }
  #content article .col-four .cols h3 {
    margin-bottom: 5px;
  }
  #content article .col-four .cols ul {
    margin: 0;
    padding: 0;
    list-style: none;
    min-height: inherit;
  }
  #content article .col-four .cols ul li {
    font-size: 12px;
  }
  #content article .col-four .cols:last-child ul {
    min-height: inherit;
  }
  #content article section {
    padding-bottom: 10px;
    overflow: hidden;
  }
  #content article section aside {
    position: absolute;
    top: 135px;
    right: 45px;
  }
  #content article section aside h3 {
    display: none;
  }
  #content article section aside .sp-cat-more {
    display: block;
    display: none;
  }
  #content article section aside ul {
    border: solid 1px #a24cb8;
    background-color: #FFF;
    width: 120px;
  }
  #content article section aside ul li {
    width: 100%;
  }
  #content article section aside ul li .sp-arrow {
    display: block;
    width: 20px;
    height: 40px;
    background: url(./images/arrow-right-purple.png) no-repeat right center;
    background-size: 10px 12px;
    position: absolute;
    top: -12px;
    right: 5px;
    -webkit-transform: rotate(90deg);
    -moz-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    -o-transform: rotate(90deg);
    transform: rotate(90deg);
  }
  #content article section aside ul li .sp-arrow.close {
    top: -5px;
    right: 5px;
    -webkit-transform: rotate(270deg);
    -moz-transform: rotate(270deg);
    -ms-transform: rotate(270deg);
    -o-transform: rotate(270deg);
    transform: rotate(270deg);
  }
  #content article section aside ul li a {
    background: none;
    background-size: 10px 12px;
    padding-left: 10px;
  }
  #content article section aside ul li.sp-cat {
    display: block;
    position: relative;
  }
  #content article section .main {
    float: none;
    width: 100%;
  }
  #content article #content-main section:first-child {
    margin-top: 40px;
  }
  #content article #content-main ul.news li {
    padding-left: 10px;
    padding-right: 10px;
  }
  #content article #content-main ul.news li .title {
    line-height: 1.4em;
  }
  #content .pagetop {
    margin-right: -20px;
    float: right;
    display: block;
    width: 40px;
    height: 40px;
    background: url(./images/pagetop.png) no-repeat left bottom;
    background-size: 40px 40px;
    z-index: 1000;
  }
  #content .stickem-container {
    position: relative;
    border: solid 1px red;
  }
  #content .stickit {
    position: fixed;
    bottom: 40px;
    width: 100%;
    border: solid 1px red;
  }
  #content .stickit-end {
    bottom: 40px;
    position: absolute;
  }

  /* footer
  -------------------------------- */
  #footer .inner {
    max-width: 520px;
    padding: 0;
    margin: 0 auto;
    padding: 22.5px 0 70px;
  }

  #footer .footer_banner_area .inner {
    padding: 35px 25px 15px;
  }

  #footer .footer_banner_area ul {
    display: block;
  }

  #footer .footer_banner_area ul li {
    width: 100%;
    box-sizing: border-box;
    padding: 0 10px 10px;
  }

  #footer .footer_banner_area ul li a {
    display: inline-block;
  }

    #footer .footer_banner_area ul li img {
    width: auto !important;
  }

  /* home
  -------------------------------- */
  #home #content article #cover {
    height: 180px;
    position: relative;
    overflow: hidden;
    z-index: 100;
  }
  #home #content article #cover .ie {
    display: none;
  }
  #home #content article .bg.black {
    padding: 0 25px;
  }
  #home #content article .bg.black section {
    max-width: 520px;
    padding: 0;
    margin: 0 auto;
  }
  #home #content article.index #content-main {
    padding-top: 30px;
  }
  #home #content article.index #content-main section {
    margin-bottom: 0;
  }
  #home #content article.index #content-main section:first-child {
    margin-top: 0;
  }
  #home #content article.index #content-main section:last-child {
    margin-bottom: 0;
  }
  #home #content article.index h2 {
    margin-bottom: 20px;
    padding-bottom: 15px;
    padding-top: none;
    border-top: none;
    border-bottom: solid 1px #999;
    font-size: 36px;
  }
  #home #content article.index h2 .title {
    padding-right: 20px;
  }
  #home #content article.index h3 {
    margin: 0 0 20px;
    font-size: 24px;
    font-weight: normal;
  }
  #home #content article.index h4 {
    margin-bottom: 5px;
  }
  #home #content article.index .cat {
    display: none;
  }
  #home #content article.index .col-four {
    margin-bottom: 40px;
  }
  #home #content article.index .news li {
    padding-left: 10px;
    padding-right: 10px;
  }
  /* #home #content article.index .news li .date,
  #home #content article.index .news li .title {
    color: #FFF;
  } */
  #home #content article.index .news li .date {
    margin-right: 20px;
  }
  #home #content article.index .news li .tag {
    margin-right: 0;
  }
  #home #content article.index .news li .title {
    padding-top: 10px;
    display: block;
    line-height: 1.4em;
  }

  /* footer
  -------------------------------- */
  #footer {
    border-top: solid 5px #6e327d;
    background-color: #000;
    color: #FFF;
    font-size: 12px;
  }
  #footer .inner {
    max-width: 520px;
    padding: 0;
    margin: 0 auto;
    padding: 22.5px 0 20px;
  }
  #footer ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  #footer small {
    font-family: 'Archivo Narrow', '游ゴシック体','Yu Gothic', YuGothic,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ヒラギノ','メイリオ', Meiryo, sans-serif;
    font-weight: 700;
    font-style: normal;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    float: none;
    display: block;
    text-align: center;
  }
  #footer .sub-menu {
    margin-bottom: 20px;
    float: none;
    text-align: center;
  }
  #footer .sub-menu li {
    display: inline-block;
  }
  #footer .sub-menu li a {
    color: #FFF;
  }
  #footer .sub-menu li a:hover {
    color: #6e327d;
  }

  /* 20251017 */
  #content article p, #content article ul, #content article ol, #content article table, #content article dl, #content article figure, #content article iframe, #content article hr, #content article h3 {
    margin-bottom: 16px;
  }

  #content article p {
    margin-top: 0px;
  }

  #content article .fl-right, #content article .fl-left {
    float: none;
    margin: 0 auto 20px;
    width: 100%;
  }

  #content article table th, #content article table td {
    display: inline-block;
    width: 100%;
  }

  #content article table.sp-row tr {
    display: flex;
    border-bottom: solid 1px #999;
  }

  #content article table.sp-row th {
    width: 100px;
  }

  #content article table.sp-row td {
    width: calc(100% - 100px);
    border-bottom: none;
  }

  #content article table th {
    border: none;
    padding-bottom: 0;
  }

  #content article table td .fl-right{
    float: right;
  }

  #about .history table img.fl-right {
    width: 150px;
    padding-left: 16px;
  }

  #content article .col-four.sp-col-two {
    margin: -30px -3.2% 0;
    width: calc(100% + 6.4%);
    /* margin-left: -3.2%;
    margin-right: -3.2%; */
  }

  #content article .col-four.sp-col-two li {
    width: calc(50% - 6.4%);
    padding-left: 3.2%;
    padding-right: 3.2%;
  }

  #content article .col-four.sp-col-two .cols {
    float: left;
  }

  #planetarium .sp-row {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 0 45px !important;
  }

  #planetarium .inner.sp-inner {
    padding: 0;
  }

  #planetarium #content article.archive .GI_TW_expander-inner .sp-row .img {
    width: 100%;
    margin: 0 auto 24px !important;
  }

  #planetarium #content article.archive .GI_TW_expander-inner .sp-row .txt {
    width: 100%;
    margin: 0 auto;
    min-height: auto;
  }

   #planetarium .GI_TW_prev span,  #planetarium .GI_TW_next span {
    margin-top: 250px;
  }

   #planetarium #content .GI_TW_expander .inner {
    width: 100%;
    padding: 0;
  }

  #planetarium article.archive .GITheWall h4 {
    margin-bottom: 0;
  }

  .pc-only {
    display: none;
  }
  .sp-only {
    display: block;
  }

  .custom-dropdown__menu {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 30px;
  }

  .custom-dropdown__all {
    margin-bottom: 10px;
    width: 100%;
  }

  .custom-dropdown__all a {
    display: block;
  }

  .target-dropdown {
    width: 100%;
  }
  
  .custom-dropdown {
    position: relative;
     width: 100%;
    margin-bottom: 5px;
  }

  .custom-dropdown__title {
    margin-bottom: 10px !important;
  }
  
  .dropdown-toggle {
    width: 100%;
    text-align: left;
    font-size: 14px;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: solid 1px #a24cb8;
    background-color: #FFF;
    padding-left: 10px;
  }
  
  .dropdown-toggle .sp-arrow {
    display: block;
    width: 10px;
    height: 20px;
    background: url(./images/arrow-right-purple.png) no-repeat right center;
    background-size: 10px 12px;
    position: absolute;
    right: 22px;
    transform: rotate(90deg) translateY(-50%);
    transform-origin: center;
  }
  
  .custom-dropdown.active .sp-arrow {
    transform: rotate(270deg) translateY(50%);
  }

  .custom-dropdown.active .dropdown-toggle {
    border-bottom: none !important;
  }
  
  .dropdown-menu {
    position: absolute;
    border-top: none !important;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    margin: 0;
    padding: 0;
    list-style: none;
    overflow-y: auto;
    display: none;
    z-index: 99;
    border: 1px solid #a24cb8;
    padding-left: 10px;
    padding-bottom: 5px;
  }
  
  .custom-dropdown.active .dropdown-menu {
    display: block;
  }
  
  .dropdown-menu li {
    margin: 0;
    padding: 0;
  }
  
  .dropdown-menu a {
    display: block;
    color: #a24cb8;
    text-decoration: none;
    transition: background 0.2s;
  }
  
  .dropdown-menu a:hover {
    background: #f5f5f5;
  }

  #content article .list-table dt {
    width: 130px;
    padding-right: 20px;
  }

  #content article .list-table dd {
    width: calc(100% - 130px);
  }

  #content article .list-table dd a {
    word-break: break-all;
  }

  .program_body {
    width: 100%;
    margin-left: 0;
  }

  #content article header h1 {
    font-size: 28px;
  }

  #content article header .tag {
    float: none;
    margin-left: 0;
    margin-top: 0;
    margin-bottom: 6px;
  }

  /* delivery destination */
  #delivery_destination #content table.search_list th {
    width: 100%;
    border-bottom: none;
  }

  #delivery_destination #content .area-select {
    position: relative;
    top: 5px;
    margin-bottom: 5px;
  }

  #delivery_destination #content table.search_list .delivery_destination__dropdown.__area td,  #delivery_destination #content table.search_list .delivery_destination__children td {
    padding: 0;
  }
  
  .search_list tr {
    display: block;
    position: relative;
  }
  
  .search_list {
    display: block !important;
    border: none;
    width: 100%;
  }
  
  .search_list tbody {
    display: block !important;
    width: 100%;
  }

  .search_list th,
  .search_list td {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box;
  }
  
  /* Main category headers (タイプ, 納入機器区分) */
  .search_list tr.delivery_destination__dropdown:not(.__area) {
    border-bottom: 1px solid #ccc;
  }

  .search_list tr.delivery_destination__dropdown:not(.__area) > th {
    padding: 15px;
    font-weight: bold;
    cursor: pointer;
    position: relative;
  }
  
  /* Add arrow to category headers */
  .search_list tr.delivery_destination__dropdown:not(.__area) > th::after {
    content: "";
    position: absolute;
    background: url(./images/arrow-right-purple.png) no-repeat left center;
    background-size: 10px 12px;
    width: 10px;
    height: 12px;
    right: 15px;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
    /* transition: transform 0.3s; */
  }
  
  .search_list tr.delivery_destination__dropdown:not(.__area).active > th::after {
    transform: translateY(-50%) rotate(270deg);
  }
  
  /* Content area - hidden by default */
  .search_list tr.delivery_destination__dropdown:not(.__area) > td {
    display: none !important;
    padding: 15px;
    border-bottom: none !important;
  }
  
  .search_list tr.delivery_destination__dropdown:not(.__area).active > td {
    display: block !important;
  }
  
  /* Region parent row (地域) */
  .search_list tr.delivery_destination__dropdown.__area {
    background: #fff;
    border-bottom: 1px solid #ccc;
  }
  
  .search_list tr.delivery_destination__dropdown.__area > th:first-child {
    padding: 15px;
    font-weight: bold;
    cursor: pointer;
    position: relative;
  }
  
  .search_list tr.delivery_destination__dropdown.__area > th:first-child::after {
    content: "";
    background: url(./images/arrow-right-purple.png) no-repeat left center;
    width: 10px;
    background-size: 10px 12px;
    height: 12px;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
    /* transition: transform 0.3s; */
  }
  
  .search_list tr.delivery_destination__dropdown.__area.active > th:first-child::after {
    transform: translateY(-50%) rotate(270deg);
  }
  
  .search_list tr.delivery_destination__dropdown.__area.active > th:first-child {
    border-radius: 4px 4px 0 0;
  }
  
  /* Show 北海道・東北 subheader and content when active */
  .search_list tr.delivery_destination__dropdown.__area > th:not(:first-child) {
    display: none !important;
    padding: 12px 15px;
    font-weight: bold;
  }
  
  .search_list tr.delivery_destination__dropdown.__area.active > th:not(:first-child) {
    display: block !important;
  }
  
  .search_list tr.delivery_destination__dropdown.__area > td {
    display: none !important;
    padding: 10px 15px 15px 15px;
    border-bottom: none !important;
  }
  
  .search_list tr.delivery_destination__dropdown.__area.active > td {
    display: block !important;
  }

   .search_list tr.delivery_destination__dropdown.__area.active {
    border-bottom: none;
   }
  
  /* Region children rows - hidden by default */
  .search_list tr.delivery_destination__children {
    display: none !important;
    border: none;
    background: transparent;
  }
  
  .search_list tr.delivery_destination__dropdown.__area.active ~ tr.delivery_destination__children {
    display: block !important;
  }
  
  .search_list tr.delivery_destination__children > th {
    padding: 12px 15px;
    font-weight: bold;
  }

   .search_list tr.delivery_destination__children:last-child {
    border-bottom: 1px solid #ccc;
    padding-bottom: 10px;
   }
  
  .search_list tr.delivery_destination__children > td {
    padding: 10px 15px 15px 15px;
    border: none !important;
  }

  #delivery-destination .table-wrap {
    overflow-x: scroll;
  }
  #delivery-destination .facility_list {
    width: 100%;
    border-collapse: collapse;
    white-space: nowrap;
  }

  #content article #delivery-destination table th, #content article #delivery-destination table td {
    display: table-cell;
  }
  
  /* recruit */
  #content .recruit table th {
    width: 100%;
    border-bottom: 1px solid #999;
  }

  #content .recruit table {
    margin-bottom: 0px;
  }

  #content .recruit table:not(:first-of-type) {
    border-top: none;
  }

  /* what is a planetarium? */
  #content article .whats_a_planetarium .header_navi {
    margin: 0  auto 50px;
  }

  #content article .whats_a_planetarium .header_navi ul {
    display: flex;
    flex-wrap: wrap;
    margin-right: -10px;
    margin-left: -10px;
    box-sizing: border-box;
  }

  #content article .whats_a_planetarium .header_navi li {
    float: none;
    width: calc(100% / 2 - 20px);
    margin: 0 0 15px;
    padding-right: 10px;
    padding-left: 10px;
  }

  #content article .whats_a_planetarium .header_navi li p {
    height: auto;
  }

  #content article .whats_a_planetarium .header_navi li.active .triangle-bottom {
    width: 100%;
  }

  #content article .whats_a_planetarium .page_anchor li {
    width: 100%;
    float: none;
    box-sizing: border-box;
  }

  .whats_a_planetarium .content-left {
    margin-right: 0;
  }

  /* our work */
  .sp-scroll {
    overflow-x: scroll;
  }

  .no-sp-wrap {
    width: 100%;
    border-collapse: collapse;
    white-space: nowrap;
  }

  #content article .sp-scroll table th, #content article .sp-scroll table td {
    display: table-cell;
    padding-right: 10px;
  }

  .content_body{
    width: 100%;
    margin-left: 0;
  }
}

