/********************** recommend_double ***********************/
.wr-recommend-image{
  background:#f3f3f3;
  border-radius:10px;
  overflow:hidden;
}

.wr-recommend-image img{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
  transition:transform .3s;
}

.wr-recommend-image:hover img{
  transform:scale(1.05);
}

.wr-recommend-body{
  font-size:16px;
  line-height:1.8;
  color:#333;
}

.wr-recommend-body p{
  margin:0;
}

.editable-recommend-h2{
  cursor:pointer;
}

.is-webrel .editable-recommend-h2:hover{
  opacity:.8;
}

.is-webrel .editable-recommend:hover,
.is-webrel .wr-recommend-image:hover{
  box-shadow:0 0 0 2px #b9dff5 inset;
  cursor:pointer;
}

/********************** media_left ***********************/
.wr-media-left{
  width:100%;
  padding-top:2em;
}

.wr-media-left-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:32px;
  align-items:center;
}

.wr-media-left-image{
  overflow:hidden;
  border-radius:14px;
  background:#f3f3f3;
  aspect-ratio:16 / 9;
}

.wr-media-left-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .3s ease;
}

.wr-media-left-image:hover img{
  transform:scale(1.05);
}

.wr-media-left-content{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.wr-media-left-kicker{
  font-size:12px;
  font-weight:700;
  letter-spacing:.16em;
}

.wr-media-left-title{
  margin:0;
  font-size:30px;
  line-height:1.4;
  color:#222;
}

.wr-media-left-body{
  font-size:16px;
  line-height:1.9;
  color:#444;
}

.wr-media-left-body p{
  margin:0;
}

.wr-media-left-button-wrap{
  margin-top:6px;
}

.wr-media-left-button-text{
  display:inline-block;
  padding:12px 22px;
  color:#fff;
  border-radius:999px;
  font-size:14px;
  font-weight:700;
}

.editable-recommend-text{
  cursor:pointer;
}

.is-webrel .editable-recommend-text:hover,
.is-webrel .editable-recommend:hover,
.is-webrel .wr-media-left-image:hover{
  box-shadow:0 0 0 2px #b9dff5 inset;
}

.recommend-inline-input{
  width:100%;
  box-sizing:border-box;
  padding:10px 12px;
  border:1px solid #cfd8e3;
  border-radius:8px;
  font-size:1em;
}

@media (max-width:768px){
  .wr-media-left-grid{
    grid-template-columns:1fr;
    gap:20px;
  }

  .wr-media-left-title{
    font-size:24px;
  }
}

/********************** cards3 ***********************/
.wr-cards3{
  width:100%;
}

.wr-cards3-section-title{
  margin:0 0 28px;
  text-align:center;
  font-size:30px;
  line-height:1.4;
  color:#222;
}

.wr-cards3-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}

.wr-card3-item{
  background:#fff;
  border:1px solid #e7edf3;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 8px 20px rgba(0,0,0,.04);
}

.wr-card3-image{
  aspect-ratio:4 / 3;
  overflow:hidden;
  background:#f3f3f3;
}

.wr-card3-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .3s ease;
}

.wr-card3-image:hover img{
  transform:scale(1.05);
}

.wr-card3-title{
  padding:18px 18px 8px;
  font-size:20px;
  font-weight:700;
  color:#222;
}

.wr-card3-body{
  padding:0 18px 20px;
  font-size:15px;
  line-height:1.9;
  color:#555;
}

.wr-card3-body p{
  margin:0;
}

.is-webrel .wr-cards3-section-title:hover,
.is-webrel .wr-card3-title:hover,
.is-webrel .wr-card3-body:hover,
.is-webrel .wr-card3-image:hover{
  box-shadow:0 0 0 2px #b9dff5 inset;
  cursor:pointer;
}

@media (max-width:900px){
  .wr-cards3-grid{
    grid-template-columns:1fr;
    gap:18px;
  }

  .wr-cards3-section-title{
    font-size:24px;
  }
}

/********************** cta ***********************/
.wr-cta-contact{
  padding:2em 20px;
  margin-top:2em;
  border-radius: 10px;
}

.wr-cta-contact-inner{
  max-width:1180px;
  margin:0 auto;
}

.wr-cta-contact-lead{
  margin:0 auto 30px;
  text-align:center;
  font-size:20px;
  line-height:1.9;
  color:#5a5a5a;
  font-weight:600;
}

.wr-cta-contact-box{
  background:#fff;
  max-width:1080px;
  margin:0 auto;
  padding:2em 54px;
  display:grid;
  grid-template-columns:1fr 1px 420px;
  gap:34px;
  align-items:center;
  border-radius:20px;
}

.wr-cta-contact-left{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.wr-cta-contact-tel-row{
  display:flex;
  align-items:baseline;
  gap:14px;
  flex-wrap:wrap;
}

.wr-cta-contact-tel-label{
  font-size:28px;
  line-height:1;
  color:#333;
  letter-spacing:0.04em;
}

.wr-cta-contact-tel-number{
  font-size:56px;
  line-height:1;
  color:#333;
  letter-spacing:0.02em;
}

.wr-cta-contact-time-row{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}

.wr-cta-contact-time-badge{
  display:inline-block;
  padding:6px 14px;
  border:1px solid #8b8b8b;
  font-size:15px;
  line-height:1;
  color:#555;
  background:#fff;
}

.wr-cta-contact-time-text{
  font-size:18px;
  color:#555;
  line-height:1.8;
}

.wr-cta-contact-divider{
  width:1px;
  height:120px;
  background:#bdbdbd;
  justify-self:center;
}

.wr-cta-contact-right{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:12px;
}

.wr-cta-contact-button-link{
  text-decoration:none!important;
  border-radius:5px;
}

.wr-cta-contact-button-text{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:92px;
  padding:18px 28px;
  color:#fff;
  font-size:34px;
  font-weight:700;
  letter-spacing:0.04em;
  position:relative;
  border-radius:999px;
}

.wr-cta-contact-button-text::after{
  content:"→";
  position:absolute;
  right:20px;
  top:50%;
  transform:translateY(-50%);
  font-size:28px;
  font-weight:400;
}

.wr-cta-contact-link-setting,
.wr-cta-contact-bg-setting{
  font-size:12px;
  color:#6f8aa3;
  text-decoration:underline;
  cursor:pointer;
  text-align:center;
}

.is-webrel .wr-cta-contact-lead:hover,
.is-webrel .wr-cta-contact-tel-label:hover,
.is-webrel .wr-cta-contact-tel-number:hover,
.is-webrel .wr-cta-contact-time-badge:hover,
.is-webrel .wr-cta-contact-time-text:hover,
.is-webrel .wr-cta-contact-button-text:hover,
.is-webrel .wr-cta-contact-link-setting:hover,
.is-webrel .wr-cta-contact-bg-setting:hover{
  box-shadow:0 0 0 2px #b9dff5 inset;
}

@media (max-width:1100px){
  .wr-cta-contact-box{
    grid-template-columns:1fr;
    gap:24px;
    padding:38px 28px;
  }

  .wr-cta-contact-divider{
    width:100%;
    height:1px;
  }

  .wr-cta-contact-right{
    max-width:520px;
    width:100%;
    margin:0 auto;
  }

  .wr-cta-contact-button-text{
    min-height:76px;
    font-size:28px;
  }

  .wr-cta-contact-tel-number{
    font-size:46px;
  }
}

@media (max-width:768px){
  .wr-cta-contact{
    padding:36px 14px;
  }

  .wr-cta-contact-lead{
    font-size:16px;
    margin-bottom:20px;
  }

  .wr-cta-contact-box{
    padding:28px 18px;
  }

  .wr-cta-contact-tel-label{
    font-size:20px;
  }

  .wr-cta-contact-tel-number{
    font-size:34px;
  }

  .wr-cta-contact-time-text{
    font-size:15px;
  }

  .wr-cta-contact-button-text{
    min-height:64px;
    font-size:22px;
  }
}

/********************** cta split ***********************/
.wr-cta-split{
  padding:2em 20px;
}

.wr-cta-split-inner{
  max-width:1100px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 420px;
  gap:60px;
  align-items:center;
}

.wr-cta-split-left{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.wr-cta-split-kicker{
  font-size:20px;
  font-weight:700;
  letter-spacing:2px;
}

.wr-cta-split-title{
  margin:0;
  font-size:36px;
  font-weight:700;
  line-height:1.5;
  color:#222;
}

.wr-cta-split-body{
  font-size:17px;
  line-height:2;
  color:#555;
}

.wr-cta-split-body p{
  margin:0;
}

.wr-cta-split-right{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.wr-cta-split-tel-box{
  background:#fff;
  border:2px solid #ddd;
  padding:25px 30px;
  box-shadow:0 6px 20px rgba(0,0,0,0.06);
  border-radius:999px;
}

.wr-cta-split-tel-row{
  display:flex;
  align-items:baseline;
  gap:10px;
  flex-wrap:wrap;
}

.wr-cta-split-tel-label{
  font-size:20px;
  font-weight:700;
}

.wr-cta-split-tel-number{
  font-size:36px;
  font-weight:700;
}

.wr-cta-split-time{
  margin-top:8px;
  font-size:14px;
}

.wr-cta-split-button-link{
  text-decoration:none !important;
}

.wr-cta-split-button{
  color:#fff;
  padding:26px 30px;
  display:flex;
  flex-direction:column;
  gap:4px;
  position:relative;
  box-shadow:0 6px 20px rgba(0,0,0,0.08);
  border-radius:999px;
}

.wr-cta-split-button-top{
  font-size:15px;
}

.wr-cta-split-button-main{
  font-size:28px;
  font-weight:700;
}

.wr-cta-split-button::after{
  content:"→";
  position:absolute;
  right:18px;
  top:50%;
  transform:translateY(-50%);
  font-size:26px;
}

.wr-cta-split-link-setting,
.wr-cta-split-color-setting{
  font-size:12px;
  color:#6f8aa3;
  text-decoration:underline;
  cursor:pointer;
}

.is-webrel .wr-cta-split-kicker:hover,
.is-webrel .wr-cta-split-title:hover,
.is-webrel .wr-cta-split-body:hover,
.is-webrel .wr-cta-split-tel-label:hover,
.is-webrel .wr-cta-split-tel-number:hover,
.is-webrel .wr-cta-split-time:hover,
.is-webrel .wr-cta-split-button-top:hover,
.is-webrel .wr-cta-split-button-main:hover,
.is-webrel .wr-cta-split-link-setting:hover,
.is-webrel .wr-cta-split-color-setting:hover{
  box-shadow:0 0 0 2px #b9dff5 inset;
}

@media (max-width:900px){
  .wr-cta-split-inner{
    grid-template-columns:1fr;
    gap:30px;
  }

  .wr-cta-split-right{
    max-width:500px;
  }

  .wr-cta-split-title{
    font-size:28px;
  }

  .wr-cta-split-tel-number{
    font-size:30px;
  }
}

/********************** recommend_access ***********************/
.wr-access{
  width:100%;
  padding-top:2em;
}

.wr-access-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:34px;
  align-items:start;
}

.wr-access-left{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.wr-access-title{
  margin:0;
  font-size:32px;
  line-height:1.4;
  color:#222;
}

.wr-access-body{
  font-size:16px;
  line-height:1.95;
  color:#555;
}

.wr-access-body p{
  margin:0;
}

.wr-access-address{
  font-size:16px;
  line-height:1.8;
  color:#333;
  font-weight:700;
}

.wr-access-time{
  font-size:14px;
  line-height:1.8;
}

.wr-access-button-wrap{
  margin-top:8px;
}

.wr-access-button-link{
  text-decoration:none;
}

.wr-access-button-text{
  display:inline-block;
  padding:13px 24px;
  color:#fff;
  border-radius:999px;
  font-size:14px;
  font-weight:700;
  text-decoration:none;
}

.wr-access-link-setting,
.wr-access-map-setting{
  margin-top:10px;
  font-size:12px;
  color:#6f8aa3;
  text-decoration:underline;
  cursor:pointer;
}

.wr-access-map{
  width:100%;
  aspect-ratio:4 / 3;
  overflow:hidden;
  border-radius:14px;
  background:#f3f3f3;
  border:1px solid #e6edf2;
}

.wr-access-map iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
}

.is-webrel .wr-access-title:hover,
.is-webrel .wr-access-body:hover,
.is-webrel .wr-access-address:hover,
.is-webrel .wr-access-time:hover,
.is-webrel .wr-access-button-text:hover,
.is-webrel .wr-access-link-setting:hover,
.is-webrel .wr-access-map-setting:hover{
  box-shadow:0 0 0 2px #b9dff5 inset;
}

@media (max-width:900px){
  .wr-access-grid{
    grid-template-columns:1fr;
    gap:22px;
  }

  .wr-access-title{
    font-size:26px;
  }
}

/********************** right ***********************/
.wr-media-right{
  width:100%;
  padding-top:2em;
}

.wr-media-right-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:32px;
  align-items:center;
}

.wr-media-right-image{
  overflow:hidden;
  border-radius:14px;
  background:#f3f3f3;
  aspect-ratio:16 / 9;
}

.wr-media-right-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .3s ease;
}

.wr-media-right-image:hover img{
  transform:scale(1.05);
}

.wr-media-right-content{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.wr-media-right-kicker{
  font-size:12px;
  font-weight:700;
  letter-spacing:.16em;
}

.wr-media-right-title{
  margin:0;
  font-size:30px;
  line-height:1.4;
  color:#222;
}

.wr-media-right-body{
  font-size:16px;
  line-height:1.9;
  color:#444;
}

.wr-media-right-body p{
  margin:0;
}

.wr-media-right-button-wrap{
  margin-top:6px;
}

.wr-media-right-button-link{
  text-decoration:none;
}

.wr-media-right-button-text{
  display:inline-block;
  padding:12px 22px;
  color:#fff;
  border-radius:999px;
  font-size:14px;
  font-weight:700;
}

.wr-media-right-link-setting{
  margin-top:8px;
  font-size:12px;
  color:#6f8aa3;
  cursor:pointer;
  text-decoration:underline;
}

.is-webrel .wr-media-right-kicker:hover,
.is-webrel .wr-media-right-title:hover,
.is-webrel .wr-media-right-body:hover,
.is-webrel .wr-media-right-button-text:hover,
.is-webrel .wr-media-right-link-setting:hover,
.is-webrel .wr-media-right-image:hover{
  box-shadow:0 0 0 2px #b9dff5 inset;
}

@media (max-width:768px){
  .wr-media-right-grid{
    grid-template-columns:1fr;
    gap:20px;
  }

  .wr-media-right-title{
    font-size:24px;
  }
}

/********************** recommend_works_carousel ***********************/
.wr-works-carousel{
  width:100%;
  padding:20px 0 10px;
}

.wr-works-carousel-title{
  margin:0 0 10px;
  font-size:34px;
  line-height:1.4;
  color:#222;
  font-weight:700;
  letter-spacing:0.02em;
}

.wr-works-carousel-track-wrap{
  position:relative;
  display:grid;
  grid-template-columns:48px 1fr 48px;
  gap:16px;
  align-items:center;
}

.wr-works-carousel-track{
  display:flex;
  gap:24px;
  overflow-x:auto;
  scroll-behavior:smooth;
  padding:10px 4px 18px;
  scrollbar-width:none;
  -ms-overflow-style:none;
}

.wr-works-carousel-track::-webkit-scrollbar{
  display:none;
}

.wr-works-card{
  flex:0 0 340px;
  background:#fff;
  border-radius:18px;
  overflow:hidden;
  border:1px solid #ddd;
  transition:transform .25s ease, box-shadow .25s ease;
}

.wr-works-card:hover{
  transform:translateY(-4px);
}

.wr-works-card-image{
  position:relative;
  aspect-ratio:4 / 3;
  overflow:hidden;
  background:#f4f4f4;
}

.wr-works-card-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .35s ease;
}

.wr-works-card:hover .wr-works-card-image img{
  transform:scale(1.06);
}

.wr-works-card-title{
  padding:20px 20px 10px;
  font-size:22px;
  line-height:1.5;
  color:#222;
  font-weight:700;
  letter-spacing:0.01em;
}

.wr-works-card-text{
  padding:0 20px 18px;
  font-size:14px;
  line-height:1.95;
  min-height:68px;
}

.wr-works-card-link{
  text-align:center;
  margin-top:12px;
  padding:0 20px 14px;
}

.wr-works-card-link a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 20px;
  border-radius:999px;
  color:#fff;
  font-size:13px;
  font-weight:600;
  letter-spacing:0.03em;
  text-decoration:none;
  transition:all .25s ease;
  text-decoration:none;
}

.wr-works-card-link a:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 14px rgba(0,0,0,0.15);
}

.wr-works-card-actions{
  padding:0 20px 20px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.wr-works-card-actions .AItextBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:72px;
  height:36px;
  padding:5px 0;
  border-radius:5px;
  font-size:14px;
  text-decoration:none;
  color:#fff;
}

.wr-works-card-actions .AItextBtn:hover{
}

.wr-works-prev,
.wr-works-next{
  width:48px;
  height:48px;
  border:none;
  border-radius:999px;
  color:#fff;
  font-size:28px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(0,0,0,.12);
  transition:transform .2s ease, opacity .2s ease, background .2s ease;
}

.wr-works-prev:hover,
.wr-works-next:hover{
  transform:translateY(-2px);
  background:#7f97ad;
}

.wr-works-carousel-footer{
  margin-top:22px;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}

.wr-works-carousel-footer .AItextBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:120px;
  height:42px;
  padding:0 18px;
  border-radius:5px;
  background:#8ea6ba;
  color:#fff;
  text-decoration:none;
  box-shadow:0 8px 20px rgba(0,0,0,.08);
}

.wr-works-carousel-footer .AItextBtn:hover{
  background:#7f97ad;
}

.is-webrel .wr-works-carousel-title:hover,
.is-webrel .wr-works-more-link-setting:hover{
  box-shadow:0 0 0 2px #b9dff5 inset;
}

@media (max-width:1024px){
  .wr-works-carousel-track-wrap{
    grid-template-columns:44px 1fr 44px;
    gap:10px;
  }

  .wr-works-card{
    flex:0 0 300px;
  }

  .wr-works-carousel-title{
    font-size:28px;
  }
}

@media (max-width:768px){
  .wr-works-carousel{
    padding:12px 0 6px;
  }

  .wr-works-carousel-title{
    font-size:24px;
  }

  .wr-works-carousel-track-wrap{
    grid-template-columns:1fr;
    gap:12px;
  }

  .wr-works-prev,
  .wr-works-next{
    display:none;
  }

  .wr-works-carousel-track{
    gap:16px;
    padding:8px 2px 12px;
  }

  .wr-works-card{
    flex:0 0 82%;
  }

  .wr-works-card-title{
    font-size:18px;
    padding:16px 16px 8px;
  }

  .wr-works-card-text{
    padding:0 16px 14px;
    font-size:13px;
    min-height:auto;
  }

  .wr-works-card-link{
    padding:0 16px 12px;
  }

  .wr-works-card-actions{
    padding:0 16px 16px;
  }

  .wr-works-carousel-footer{
    margin-top:16px;
    gap:12px;
  }
}

/* 編集用 */
.editable-recommend{
  cursor:pointer;
}

.is-webrel .editable-recommend:hover{
  box-shadow:0 0 0 2px #b9dff5 inset;
}

.recommend-inline-editor{
  margin-top:8px;
}

.recommend-inline-textarea{
  width:100%;
  min-height:140px;
  padding:12px;
  border:1px solid #cfd8e3;
  border-radius:8px;
  font-size:15px;
  line-height:1.8;
  resize:vertical;
  box-sizing:border-box;
}

.recommend-inline-actions{
  margin-top:10px;
  display:flex;
  gap:10px;
}

.recommend-save-btn,
.recommend-cancel-btn{
  border:none;
  border-radius:5px;
  cursor:pointer;
  padding:5px 0;
  font-size:14px;
  width:80px;
}

.recommend-save-btn{
  background:#9FB2C3;
  color:#fff;
}

.recommend-cancel-btn{
  background:#666;
  color:#fff;
}

.recommend-link-editor{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.recommend-link-type{
  padding:8px;
  border:1px solid #ccc;
  border-radius:6px;
}

.recommend-link-input{
  padding:10px;
  border:1px solid #ccc;
  border-radius:6px;
}

.recommend-page-list{
  border:1px solid #ddd;
  border-radius:8px;
  max-height:200px;
  overflow:auto;
}

.recommend-page-item{
  padding:8px 10px;
  cursor:pointer;
}

.recommend-page-item:hover{
  background:#f3f7fb;
}