@charset "UTF-8";

/*/////////////////////////////////////////////
ベース
/////////////////////////////////////////////*/
i{
 margin-right: 3px;
}
p{
 line-height: 1.5;
}
/*/////////////////////////////////////////////
2カラムベース
/////////////////////////////////////////////*/
.container_2col {
 display: grid;
 grid-template-columns: 3fr 1fr;
 gap: 20px;
 max-width: 1200px;
 margin: 0 auto;
 padding: 20px;
 box-sizing: border-box;
 align-items: flex-start;
}

.main-content {
 padding: 20px;
}

.sidebar {
 padding: 0px;
 margin-top: 20px;
 position: sticky;
 top: 70px;
}

@media screen and (max-width: 767px) {
.container_2col {
 grid-template-columns: 1fr;
 gap: 20px;
}
.main-content {
 padding: 0px;
}
.sidebar {
 padding: 0px;
}
}

/*/////////////////////////////////////////////
倉庫リスト
/////////////////////////////////////////////*/
.souko-list{
 display: block;
 border: 1px solid #c1c1c1;
 padding: 10px;
 margin: 30px auto 0;
}
.souko-list h3{
 display: block;
 background: #1a17ae;
 padding: 10px 20px;
 color: #fff;
 font-weight: 600;
 font-size: 1.3em;
 margin-bottom: 10px;
}
.souko-date{
 display: grid;
 grid-template-columns: 300px 1fr;
 gap: 20px;
 align-items: flex-start;
}
@media screen and (max-width: 767px) {
.souko-date{
 grid-template-columns: 1fr;
}
}
.price{
 font-weight: bold;
 font-size: 1.3em;
 color: red;
}
.price span{
 display: inline-block;
 margin-left: 5px;
 font-size: 0.5em;
}

.souko-table {
 border-collapse: collapse;
 width: 100%;
}
.souko-table th,
.souko-table td {
 border-bottom: 1px solid #dbe1e8;
 padding: 15px 0;
}

.souko-table th {
 background: #fff;
 text-align: left;
 width: 120px;
}

.souko-table tr:first-child {
 border-top: 1px solid #dbe1e8;
}

@media screen and (max-width: 767px) {
.souko-table tr,
.souko-table th,
.souko-table td {
 display: block;
 width: auto;
}
.souko-table tr:first-child {
 border-top: 1px solid #dbe1e8;
}
.souko-table th,
.souko-table td {
 border-top: none;
}
}

.souko-under{
 display: grid;
 margin-top: 5px;
 grid-template-columns: 1fr 200px;
 align-items: end;
}
@media screen and (max-width: 767px) {
.souko-under{
 grid-template-columns: 1fr;
}
}
.souko-under ul{
 display: flex;
 gap: 10px;
 align-items: center;
 flex-wrap: wrap;
 list-style: none;
 justify-content: left;
}
@media screen and (max-width: 767px) {
.souko-under ul{
 margin: 20px auto;
 justify-content: center;
}
}
.souko-under ul li img{
 display: block;
 width: 80px;
 height: 80px;
}

/*詳細はこちらボタン*/
.syosai-btn a {
 position: relative;
 display: flex;
 justify-content: space-around;
 align-items: center;
 margin: 0 auto;
 max-width: 230px;
 padding: 10px 0px 10px 25px;
 line-height: 1.8;
 text-decoration: none;
 color: #333;
 transition: 0.3s ease-in-out;
 font-weight: 500;
}
.syosai-btn a:before, .syosai-btn a:after {
 content: "";
 position: absolute;
 display: block;
 top: 50%;
}
.syosai-btn a:before {
 width: 0.5rem;
 height: 0.5rem;
 left: 1.1rem;
 border-top: solid 2px #fff;
 border-right: solid 2px #fff;
 z-index: 2;
 transform: translateY(-50%) rotate(45deg);
 transition: all 0.3s;
}
.syosai-btn a:after {
 left: 0;
 background: #1a17ae;
 z-index: 1;
 width: 3rem;
 height: 3rem;
 border-radius: 4rem;
 transform: translateY(-50%);
 transition: all 0.5s;
}
.syosai-btn a span {
 position: relative;
 transition: all 0.3s;
 z-index: 3;
}
.syosai-btn a:hover {
 opacity: 1;
}
.syosai-btn a:hover span {
 color: #fff;

}
.syosai-btn a:hover:before {
 left: 2.5rem;
 border-top: solid 2px #fff;
 border-right: solid 2px #fff;
}
.syosai-btn a:hover:after {
 right: 0;
 width: 100%;
}


/*/////////////////////////////////////////////
サイドバー
/////////////////////////////////////////////*/
.area-now{
 display: block;
}
.area-now h3{
 display: flex;
 background: #26368c;
 padding: 10px;
 justify-content: center;
 align-items: center;
 font-weight: bold;
 color: #fff;
 gap: 10px;
}
.area-now h3 svg{
 width: 20px;
 height: auto;
 fill: #fff;
}
.area-now-inner{
 display: block;
 border: 1px solid #26368c;
 padding: 15px;
 text-align: center;
}
.area-now-display span{
 font-size: 1.5em;
 font-weight: bold;
 margin-left: 5px;
}

.side-contact{
 display: block;
 padding: 10px;
 border: 1px solid #26368c;
 text-align: center;
 font-weight: bold;
 color: #26368c;
}
.area-now-inner p{
 display: block;
 margin: 10px auto;
}
.area-now-inner .free-link02{
 display: block;
 font-size: 1.5em;
}
.area-now-inner .free-link02::before{
 width: 60px;
}
.area-contact-time{
 display: block;
 background: #fff232;
 color: #333;
 text-align: center;
 padding: 3px 0;
 font-weight: bold;
}


/*/////////////////////////////////////////////
倉庫詳細ページ
/////////////////////////////////////////////*/
.souko-name-title{
 display: block;
 background: #1a17ae;
 padding: 10px 20px;
 color: #fff;
 font-weight: 600;
 font-size: 2em;
 margin-bottom: 10px;
}

/*スライダー*/
/* Swiper共通の最低限のCSS */
.swiper {
 width: 100%;
 overflow: hidden;
 height: fit-content!important;
 margin-top:10px;
}
.swiper-wrapper {
 display: flex;
}
.swiper-slide {
 flex-shrink: 0;
 width: 100% !important;
}
.main-slider {
 width: 100%;
 height: auto;
}
.main-slider img {
 width: 100%;
 height: 500px;
 object-fit: cover;
 display: block;
}

/* サムネイルスライダー用 */
.thumbs-slider .swiper-slide {
 flex-shrink: 0;
 width: 130px!important;
 opacity: 0.4;
 cursor: pointer;
}
.thumbs-slider .swiper-slide img{
 display: block;
 width: 130px!important;
 height: 130px!important;
 object-fit: cover;
}
.thumbs-slider .swiper-slide-thumb-active {
 opacity: 1;
 border: 2px solid #333;
 height: fit-content;
}
.thumbs-slider {
 overflow: hidden;
 height: 130px;
}
.swiper-free-mode > .swiper-wrapper{
 flex-wrap: wrap;
}

/* PC・タブレット用（デフォルト） */
.thumbs-slider .swiper-slide {
  width: 130px !important;
}
.thumbs-slider .swiper-slide img {
  width: 130px !important;
  height: 130px !important;
}

/* スマホ用 */
@media (max-width: 768px) {
  .thumbs-slider .swiper-slide {
    width: 65px !important;
  }
  .thumbs-slider .swiper-slide img {
    width: 65px !important;
    height: 65px !important;
  }
  .main-slider {
    height: auto;
  }
  .main-slider img {
  height: 200px;
  }
}

.info-message{
 display: grid;
 grid-template-columns: 100px 1fr;
 align-items: center;
 background-color: #f3fafe;
 padding: 20px;
 gap: 30px;
 margin: 30px auto;
}
@media (max-width: 768px) {
.info-message{
 gap: 10px;
 grid-template-columns: 60px 1fr;
}
}

.syousai-h3{
 display: block;
 font-size: 1.5em;
 color: #26368c;
 margin-bottom: 30px;
}

/*料金一覧テーブル*/
.table-container {
 width: 100%;
 overflow-x: auto;
 margin: 30px auto 50px;
}
/* PC表示 */
.responsive-table {
 width: 100%;
 border-collapse: collapse;
 font-size: 16px;
}
.responsive-table th,
.responsive-table td {
 border: 1px solid #ddd;
 padding: 12px;
 text-align: center;
}
.responsive-table th {
 background: #f5f5f5;
 font-weight: bold;
}

/* ボタン風 */
.table-btn {
 display: block;
 padding: 12px 16px;
 text-align: center;
 background: linear-gradient(45deg, #ff7f50, #f06);
 color: #fff;
 text-decoration: none;
 border-radius: 4px;
 font-size: 14px;
}

/* スマホ表示 */
@media (max-width: 768px) {
.responsive-table thead {
 display: none; /* ヘッダー非表示 */
}
.responsive-table tr {
 display: block;
 margin-bottom: 20px;
 border: 1px solid #ddd;
}
.responsive-table td {
 display: block;
 text-align: left;
 padding: 10px;
 border: none;
 border-bottom: 1px solid #eee;
}
.responsive-table td:last-child {
 border-bottom: none;
}
.responsive-table td:before {
 content: attr(data-label);
 font-weight: bold;
 display: block;
 margin-bottom: 5px;
 color: #555;
}
}

/*アコーディオン*/
.acd_details {
 color: #000;
 line-height: 2;
 background: #f3fafe;
 width: 100%;
 margin: 0px auto 50px;
}
.acd_details_title {
 position: relative;
 display: block;
 background: #26368c;
 color: #fff;
 cursor: pointer;
 margin: 0;
 padding: 10px 40px 10px 16px;
 font-weight: bold;
}
.acd_details_title::-webkit-details-marker {
 display: none;
}
.acd_details_title::before {
 display: block;
 content: "";
 box-sizing: border-box;
 position: absolute;
 top: calc(50% - 6px);
 right: 16px;
 width: 6px;
 height: 6px;
 border: 6px solid transparent;
 border-left: 6px solid #fff;
 transition: all 0.4s ease-out;
 transform-origin: 3px 6px;
 transform: rotate(90deg);
}
.acd_details[open] .acd_details_title::before {
 transform: rotate(-90deg);
}
.acd_content {
 overflow: hidden;
 margin: 0;
 padding: 0 20px;
}
.acd_content ul{
 margin: 20px auto;
 padding: 0 40px;
}
.acd_content > * {
 margin: 0;
 padding-top: 16px;
}
.acd_content > *:last-child {
 padding-bottom: 16px;
}
.acd_content p{
 display: block;
 background: #fff;
 padding: 20px;
 margin-bottom: 30px;
}
@media (max-width: 768px) {
.acd_content ul{
 padding: 0 20px;
}
}
