/* -fix_20221210_uetani- */
main #right_column { margin-top: 80px;}
div#hospital { width: 100%;padding: 0 15px; box-sizing: border-box;}
@media screen and (min-width: 768px){
 #wrap { width:100%; max-width: 1220px;margin: 10px auto;}
 #container {width:100%; max-width: 1220px;}
 main #left_column {width: 30%;max-width: 300px; box-sizing: border-box; margin: 0;}
 main #right_column {width: 70%;flex: 1;box-sizing: border-box;margin: 0;}
 #pankuzu {padding: 0 15px;box-sizing: border-box; }
 div#hospital {width: 100%;max-width: 920px;padding: 0 15px; box-sizing: border-box; }
 div#hospital section#price dl.table dd, div#hospital section#deadline dl.table dd { max-width: 195px; }
 div#hospital section#deadline .box_wrap .box h4 {max-width: 190px;}
}

.size_img img{border-radius:10px;max-width:100%;width: 600px;}
.size_img {text-align: center;}
.jump-nav{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:12px;
  margin: 18px 0 30px;
}


/* jumpボタン*/


.jump-nav__btn{
  position:relative;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:6px;
  padding:14px 10px;
  border-radius:16px;
  border:1px solid #dfe3ea;
  background:#c3d3ff;
  text-decoration:none;
  font-weight:bold;
  color:#0202e5;
  box-shadow: 0 6px 18px rgba(15, 23, 42, .08);
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    background-color .18s ease,
    border-color .18s ease,
    color .18s ease;
}

.jump-nav__btn:hover{
  transform: translateY(-2px);
  background: linear-gradient(180deg, #f6f8ff, #ffffff);
  border-color: #0202e5;
  box-shadow: 0 12px 26px rgba(2, 2, 229, .18);
  color:#0202e5;
}

.jump-arrow{
  display:inline-block;
  font-size:16px;
  transform: translateX(0);
  transition: transform .18s ease;
}

.jump-nav__btn:hover .jump-arrow{
  transform: translateX(3px);
}

.jump-nav__btn:active{
  transform: translateY(0);
  box-shadow: 0 6px 14px rgba(15, 23, 42, .12);
}

@media screen and (max-width: 768px){
  .jump-nav{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap:10px;
  }
  .jump-nav__btn{
    padding:14px 8px;
    font-size:14px;
  }
}

@media (prefers-reduced-motion: reduce){
  .jump-nav__btn,
  .jump-arrow{
    transition:none;
  }
}

/* ===== PhotoWear Intro ===== */
.pw-intro{
  width: 900px;
  max-width: 95%;
  margin: 0.5rem auto 1.8rem;
  background: #fff;
  border: 1px solid #e6e9f2;
  border-radius: 16px;
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
  overflow: hidden;
}
.pw-intro__hd{
  padding: 18px 8px;
  border-bottom: 1px solid #eef1f7;
}
.pw-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size: 13px;
  color:#0b2cff;
  padding:6px 10px;
  font-weight: 700;
}
.pw-intro__title{
  margin: 10px 0 18px;
  font-size: clamp(18px, 2.2vw, 22px);
  line-height: 1.45;
  font-weight: 800;
  color:#0f172a;
}
.pw-intro__lead{
  font-size: 16px;
}



/* フォトウェア体裁*/
.pw-sell__hd{
  border-bottom: 1px solid #eef1f7;
  text-align: center;
}
.pw-sell__badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size: 13px;
  font-weight: 900;
  color:#0b2cff;
  padding:6px 10px;

}
.pw-sell__ttl{
  margin: 10px 0 6px;
  font-size: clamp(18px, 2.4vw, 24px);
  line-height: 1.45;
  font-weight: 900;
  color:#0f172a;
}
.pw-sell__lead{
  margin: 0;
  font-size: 14px;
  line-height: 1.9;
  color:#334155;
}
.pw-sell__hero{
  padding: 14px 16px 0;
}
.pw-sell__hero img{
  display:block;
  width:100%;
  border-radius: 14px;
  border:1px solid #e7ebf4;
}
.pw-sell__body {
  margin-right:18px;
}
.pw-sell__chips{
  display:flex;
  flex-wrap: wrap;
  gap:8px;
  justify-content:center;
  margin: 12px 0 10px;
}
.pw-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 12px;
  background:#fff;
  font-size: 13px;
  font-weight: 800;
  color:#0f172a;
}
.pw-chip i{
  width:10px;height:10px;border-radius:50%;
  background:#0b2cff; display:inline-block;
}

.pw-step{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding: 12px;
  border-radius: 14px;
  border:1px solid #e7ebf4;
  background: #ffffff;
  margin:10px;
    font-family: sans-serif;
}

.pw-step__num{
  flex:0 0 auto;
  width: 200px;
  height: 200px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  display:inline-block;
  padding:4px 8px;
  margin-bottom: 8px;
}
.pw-step__txt h4{
  font-size: 18px;
  font-weight: 500;
  color:#0f172a;
  margin-top:40px;
}
.pw-step__txt p{
  margin: 0;
  font-size: 16px;
  line-height: 1.7;
  padding:20px;
}


/* フォトウェアギャラリー_カード*/

.pw-sell__gallery{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:10px;
  font-family: sans-serif;
}
.pw-mini{
  border-radius: 14px;
  border: 1px solid #e7ebf4;
  overflow:hidden;
  background:#fff;
}
.pw-mini img{
  display:block;
  width:100%;
  object-fit: cover;
}
.pw-mini__cap{
  padding: 10px 10px 12px;
  font-size: 13px;
  line-height: 1.6;
  color:#334155;
}
.pw-mini__cap b{
  font-weight: 900;
  color:#0f172a;
}


.card_image {
    display: block;
    width: 650px;
    max-width: 100%;
}

/* ===== フォトウェア：ご利用の流れ ===== */
.pw-flow-lead{
  margin: 0 0 14px;
  font-size: 15px;
  line-height: 1.9;
}

.pw-flow{
  width: 900px;
  max-width: 95%;
  margin: 0 auto;
  gap: 12px;
}



.pw-flow__num{
  background: #789af7;
  color: #fff;
  font-weight: bold;
  padding: 10px 12px;
  text-align: center;
}

.pw-flow__body{
  padding: 14px 14px 50px;
}

.pw-flow__ttl{
  margin: 2px 0 8px;
  font-size: 18px;
  line-height: 1.45;
  text-align: center;
}

.pw-flow__txt{
  margin: 0;
  font-size: 15px;
  line-height: 1.85;
}

.pw-flow__tips,
.pw-flow__note{
  margin-top: 12px;
  padding: 12px;
  border-radius: 12px;
  background: #f6f8ff;
  border: 1px solid #dbe4ff;
}

.pw-flow__note{
  background: #fff7f2;
  border: 1px solid #ffd7bf;
}

.pw-flow__tip-ttl,
.pw-flow__note-ttl{
  margin: 0 0 8px;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  border-radius:12px;
}

.pw-flow__list{
  margin: 0;
  font-size: 14px;
  line-height: 1.8;
}



@media screen and (max-width: 768px){
  .pw-flow-lead{font-size: 14px;}
  .pw-flow__ttl{font-size: 16px;}
  .pw-flow__txt{font-size: 14px;}
  .pw-flow__list{font-size: 13px;}
}

.s-midashi{
    font-size: 20px;
    font-weight: bold;
    color: #ff5b5b;
    margin-bottom: 10px;
    border-bottom: solid 2px #ff5b5b;
    display: inline-block;
    padding: 0 15px 0;
    margin-left:13px;
}


/* フォトウェア_レスポンシブ*/

@media (max-width: 768px){
  .pw-sell__gallery{
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
  }

  .pw-sell__gallery .pw-mini{
    flex: 0 0 78%;
    max-width: 78%;
    scroll-snap-align: start;

    border-radius: 14px;
  }

  .pw-sell__gallery .pw-mini img{
    width: 100%;
    aspect-ratio: 4 / 3;  
    object-fit: cover;
  }


  .pw-sell__gallery::-webkit-scrollbar{
    height: 6px;
  }


.pw-step__num{  width: 140px;height: 140px;}
.pw-step__txt h4{ font-size:18px;margin:0;}
.pw-step__txt p{ font-size:16px;margin-bottom: 4px;}


  .pw-step{
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .pw-step__num img{
    width: 160px;    
    max-width: 70%;
    height: auto;
    display: block;
    margin: 0 auto;
  }


  .pw-step__txt{
    width: 100%;
    padding-top: 6px;
  }

  .pw-step{
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow: hidden; 
  }




  .pw-step__num img{
    width: 160px;
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
  }

  .pw-step__txt{
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding：20px；
  }
}

}


/* ─────────────────────────────
   TOP-textbox
───────────────────────────── */
.TOP-textbox{
/* background: linear-gradient(90deg, #f5f8ff 0%, #eaf0ff 100%); */
border:4px solid #ff2020ff;
border-radius: 6px;
padding: 15px 20px;
width: 800px;
max-width: 93%;

text-align: center;
box-shadow: 0 3px 10px rgba(0,0,0,0.08);
}
.TOP-textbox span{
  font-size:18px;
  color:red;
  font-weight:bold;
}


@media screen and (max-width: 768px){
  .TOP-textbox{
    padding: 20px 10px;
    border-radius: 8px;
  }

  .TOP-textbox a{
    padding: 3px 8px;
  }
}


.TOP-textbox{
  margin: 0 auto;
}


.imp{width:690px;max-width:90%;margin:0 auto;}
.imp h4{font-size:1.3rem;display:flex;align-items:center;font-weight:bold;margin:.2rem auto .7rem;border-bottom:2px solid;width:fit-content;text-align:center}
.imp h4 img{width:1.5rem;height:1.5rem;margin-right:5px;}
.imp p{margin:.2rem 1.5rem;}
.b-border{padding:.5rem;border-radius:.4rem;border:4px solid red;}
/* アコーディオン */
.accordion_wrapper {width:90%;margin: 1.5rem auto;}
.accordion-box {border: 1px solid #ccc;border-radius:.4rem;margin-bottom: 10px;overflow: hidden;}
.accordion-box summary {cursor:pointer;padding:1rem;font-size: clamp(0.9rem, 2.5vw, 1rem);font-weight:bold;display:flex;align-items: center;justify-content: space-between;list-style:none;-webkit-appearance:none;}
.accordion-box summary::-webkit-details-marker {display: none !important;}
.accordion-box summary .icon {transition:transform 0.3s ease;color:#fff;font-size:1.5rem;}
summary h3{text-align: center;font-size:1.1rem!important;color:#ffffff!important;width: fit-content;margin: 0 auto;border:none!important;}
summary h3 span{color:#ffff00;}
.accordion-box summary h4{text-align:center;font-size:1.2rem!important;color:#ffffff!important;width:fit-content;margin: 0 auto;}
.accordion-box summary h4 span{color:#ffff00;}
details[open] summary .icon {transform: rotate(180deg);}
.accordion-box p {padding: 1rem;margin: 0;background: #fff;font-size:.8rem;}
.accordion-box p a{font-weight:bold;border-bottom:2px solid;}
.accordion-box h5{padding:0 12px;font-size: 16px;color:#000c9b;font-weight: bold;}
.accordion-box ul li{font-size:.9rem;margin:0.5rem;}
.bc-img{width:100%;margin:1vh auto;display:flex;flex-wrap: wrap;}
.bc-img img{width: 800px;max-width: 100%;margin: 0 auto;}
#nyukou-sec h4{padding:.4rem;font-size:1.1rem;font-weight: bold;color: #fff;width:fit-content;margin:0 auto;}
#nyukou-sec>.accordion_wrapper{width:80%;margin:0 auto;}
#nyukou-sec>.accordion_wrapper>.accordion-box summary{background: #00078d;padding:.5rem;}
.pad-1rem{padding:.2rem 1rem;}
.pad-1rem p{font-size:1rem;margin:.3rem 0;}
#nyukou-sec{padding:.2rem 1rem;font-size:1rem;}
#nyukou-sec>#nyukou-summary>.accordion-box summary{background:#000;}
@media screen and (max-width:768px){
	#nyukou-sec>.accordion_wrapper{width:100%;}
	.pad-1rem{padding:.2rem .5rem;}
}
/* アコーディオン end*/

#designOP-button{display:block;width:fit-content;margin:0 auto;}
#designOP-button img{display: block;width: 315px;max-width:85%;margin:auto;border-radius:.4rem;box-shadow: 4px 6px 5px #989898;}
#designOP-button:hover{transform:scale(1.05);}

.pad-1rem{padding:.2rem 1rem;}
.pad-1rem p{font-size:1rem;margin:.3rem 0;}
.nyukou-sec{padding:.2rem 1rem;font-size:1rem;}
.nyukou-sec h4{padding:.4rem;font-size:1.1rem;font-weight: bold;background: #0202e5;color: #fff;width:fit-content;margin:.5rem 0;}
.img-sec{display:flex;justify-content:center;margin:2rem auto;}
.img-sec a {display:block;width:350px;max-width:48%;margin:0.5rem;}
.img-sec a img{display:block;width:100%;border:2px solid;border-radius:.4rem;}
@media (max-width:495px) {
	.img-sec{flex-direction:column;align-items:center;}
	.img-sec a{max-width:90%;}
}
.font01{margin:0 auto;padding:0 1.2rem;}
.font01 h4{font-size:1.1rem;font-weight:bold;}
.font01 p{font-size:.9rem;margin:.2rem .5rem;}


/* アコーディオン */
.animated {-webkit-animation-duration: 1s;animation-duration: 1s;-webkit-animation-fill-mode: both;animation-fill-mode: both;}
.content-wrap {position: relative;overflow: hidden;transition: height 0.3s ease;}
.close-btn, .more-btn {display: block;width: 100%;padding: 45px 0 0;position: absolute;bottom: 0;left: 0;text-align: center;background: -moz-linear-gradient(top,rgba(255, 255, 255, 0) 0%,rgba(255, 255, 255, 1) 60%);
background: -webkit-linear-gradient(top,rgba(255, 255, 255, 0) 0%,rgba(255, 255, 255, 1) 60%);
background: linear-gradient(to bottom,rgba(255, 255, 255, 0) 0%,rgba(255, 255, 255, 1) 60%);
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffffff',endColorstr='#ffffff',GradientType=0);z-index:2;}
.close-btn {background: none;}
.slide-up {
padding-bottom: 0;}
.slide-down {padding-bottom: 50px;}
.more-btn p,.close-btn p {display: inline-block;color: #fff;cursor: pointer;padding: 5px 20px;width: 25%;border-radius: 20px;font-size: 1.1rem;font-weight: bold;}
.more-btn p {background: linear-gradient(45deg, #ff4e2f, #ecd00f);animation: blinkAnime 1s infinite alternate;}
@keyframes blinkAnime{
   0% { color: #fff }
 100% { color: #55ff5dff }
}
.close-btn {padding:0;}
.close-btn p {background: #aaa; }
.content-wrap {
--content-txt: 16px;
.content-txt {
font-size: var(--content-txt);}}
@media (max-width: 768px) {.more-btn p,.close-btn p {font-size: 1rem; width: 40%;}}
/* アコーディオン end */


/* 横スクロール案内：PCでは非表示、横スクロール表示時だけ出す */
.hscroll-hint{
  display:none;
  width: 900px;
  max-width: 95%;
  margin: 8px auto 10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid #e7ebf4;
  background: #fff;
  box-shadow: 0 8px 20px rgba(15,23,42,.06);
  color:#0f172a;
  font-family: sans-serif;
  align-items:center;
  justify-content:center;
  gap:10px;
}

.hscroll-hint__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background:#eef2ff;
  border:1px solid #cfd8ff;
  color:#0b2cff;
  font-weight:900;
  line-height:1;
}

.hscroll-hint__text{
  font-size: 13px;
  font-weight: 900;
  color:#334155;
}

@media (max-width: 768px){
  .hscroll-hint{
    display:flex;
  }
}


.hscroll-wrap{
  position:relative;
}


.hscroll-wrap::after{
  content:"";
  pointer-events:none;
  position:absolute;
  top:0;
  right:0;
  width: 56px;
  height: 100%;
  background: linear-gradient(to left, rgba(255,255,255,1), rgba(255,255,255,0));
  opacity:0;
  transition: opacity .2s ease;
}


@media (max-width: 768px){
  .hscroll-wrap::after{
    opacity:1;
  }
}

.hscroll-wrap.is-scrolled::after{
  opacity:0;
}


/* 下層商品案内（フォトパーカー / フォトスウェット） */
.pw-subnav{
  display:grid;
  grid-template-columns: 1fr;
  gap:10px;
  margin-top: 10px;
}

.pw-subnav__btn{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid #dbe4ff;
  background:#ffffff;
  color:#0b2cff;
  text-decoration:none;
  font-weight:700;
}

.pw-subnav__btn:hover{
  border-color:#0b2cff;
}

.pw-subnav__arrow{
  font-size:18px;
  line-height:1;
}

@media (min-width: 768px){
  .pw-subnav{
    grid-template-columns: 1fr 1fr;
  }
}


/* ===== フォトウェア料金テーブル：中央寄せ＆スマホ最適化 ===== */
.fee-table{
  table-layout: fixed; /* 幅比率を固定して崩れにくくする */
}

.fee-table th,
.fee-table td{
  text-align: center;    
  vertical-align: middle;
  line-height: 1.6;
  word-break: break-word;   
  overflow-wrap: anywhere;
}


.trimming p {
    padding: 16px 12px 0;
}


/* ===== 動機づけクロージング Section ===== */
.pw-idea{
  max-width: 100%;
}

.pw-idea__hd{
  padding: 18px 16px 12px;
  text-align: center;
  border-bottom: 1px solid #eef1f7;
}
.pw-idea__badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size: 13px;
  font-weight: 900;
  color:#0b2cff;
  padding:6px 10px;

}
.pw-idea__ttl{
  margin: 10px 0 8px;
  font-size: clamp(18px, 2.6vw, 24px);
  line-height: 1.45;
  font-weight: 900;
  color:#0f172a;
}
.pw-idea__lead{
  margin: 0;
  font-size: 14px;
  line-height: 1.9;
  color:#334155;
}



.pw-idea__grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 50px 0 0;
}

.pw-card{
  border: 1px solid #e7ebf4;
  border-radius: 16px;
  background: #fff;
  overflow: hidden;
}
.pw-card__img{
  display:block;
  width:100%;
  border-bottom: 1px solid #eef1f7;
  background: #f8fafc;
}
.pw-card__img img{
  display:block;
  width:100%;
  height:auto;
}
.pw-card__bd{
  padding: 12px 12px 14px;
  font-family: sans-serif;
}
.pw-card__kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size: 12px;
  font-weight: 900;
  color:#0b2cff;
  background:#eef2ff;
  border:1px solid #cfd8ff;
  padding:5px 9px;
  border-radius: 999px;
}
.pw-card__ttl{
  margin: 10px 0 6px;
  font-size: 16px;
  font-weight: 900;
  color:#0f172a;
  line-height: 1.5;
}
.pw-card__txt{
  margin: 0;
  font-size: 14px;
  line-height: 1.85;
  color:#334155;
}

.pw-idea__tips{
  margin-top: 14px;
  border: 1px solid #dbe4ff;
  background: #f6f8ff;
  border-radius: 14px;
  padding: 12px;
  font-family: sans-serif;
}
.pw-idea__tips h4{
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 900;
  color:#0f172a;
  text-align: center;
  font-family: sans-serif;
}
.pw-tiplist{
  list-style: none;
  margin: 0;
  padding: 0;
  display:grid;
  gap: 20px;
}
.pw-tip{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding: 10px;
  border-radius: 12px;
  background: #fff;
  border: 1px solid #e7ebf4;
}
.pw-dot{
  width:10px;height:10px;border-radius:50%;
  margin-top: 6px;
  background:#0b2cff;
  flex:0 0 auto;
}
.pw-tip b{
  display:block;
  font-size: 14px;
  font-weight: 900;
  color:#0f172a;
  margin-bottom: 2px;
}
.pw-tip p{
  margin: 5px;
  font-size: 14px;
  line-height: 1.8;
  color:#334155;
}

.pw-idea__mini{
  margin-top: 12px;
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}


/* ギャラリー（スマホは横スクロール） */
@media (max-width: 768px){
  .pw-idea__grid{
    display:flex;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    padding-bottom: 6px;
  }
  .pw-card{
    flex: 0 0 85%;
    max-width: 85%;
    scroll-snap-align: start;
  }
  .pw-idea__lead{font-size: 14px;}
}
@media (prefers-reduced-motion: reduce){
  .pw-idea__grid{scroll-behavior:auto;}
}

