/* CSS Document */

.medPopup{ position: fixed; inset: 0; z-index: 99999; display: none; }
.medPopup.is-open{ display: block; }

.medPopup__backdrop{
  position: absolute; inset: 0;
  background: rgba(0,0,0,.55);
}

.medPopup__panel{
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: min(920px, calc(100vw - 32px));
  max-height: calc(100vh - 32px); /* ★スマホで画面外に出ない */
  overflow: auto;                /* ★中だけスクロール */
  background: #fbf6eb;
  border-radius: 18px;
  border: 3px solid #a68a3a;
  box-shadow: 0 10px 40px rgba(0,0,0,.35);
}

.medPopup__close{
  position: sticky; /* スクロールしても右上に居る */
  top: 12px;
  margin-left: auto;
  right: 0;
  display: block;
  width: 36px; height: 36px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.2);
  background: rgba(255,255,255,.6);
  font-size: 20px;
  cursor: pointer;
}

.medPopup__body{ padding: 22px 40px 34px; text-align: center; }

.medPopup__logo{
  width: 68px;
  height: auto;
  display: block;
  margin: 0 auto 10px;
}

.medPopup__kicker{
  font-size: 13px;
  letter-spacing: .12em;
  color: #7b6a35;
  margin-bottom: 10px;
}

.medPopup__title{
  font-size: clamp(22px, 3vw, 34px);
  margin: 0 0 14px;
  color: #1f1f1f;
}

.medPopup__text{
  margin: 0 auto 18px;
  max-width: 760px;
  line-height: 1.9;
  color: #2a2a2a;
  font-size: 15px;
}

.medPopup__tags{
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0 0 22px;
}

.medPopup__tag{
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(166,138,58,.55);
  background: rgba(255,255,255,.45);
  font-size: 13px;
  color: #6d5b2b;
}

.medPopup__actions{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  max-width: 620px;
  margin: 0 auto;
}

.medPopup__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 56px;
  border-radius: 12px;
  text-decoration: none;
  font-weight: 800;
  border: 2px solid rgba(31,31,31,.35);
  color: #1f1f1f;
  background: #fff;
  padding: 0 14px;
}

.medPopup__btn--primary{
  border-color: rgba(166,138,58,.9);
  background: linear-gradient(180deg, #d9be73, #b08a2a);
  color: #ffffff;
  text-shadow: 0 1px 1px rgba(0,0,0,.25);
}
.medPopup__btn:hover{ filter: brightness(1.05); }

@media (max-width: 640px){
  .medPopup__body{ padding: 18px 16px 22px; }
  .medPopup__actions{ grid-template-columns: 1fr; } /* ★スマホは縦並び */
  .medPopup__btn{ height: 52px; }
}

/* タイトル */
.medPopup__title{
  font-family:
    "Yu Mincho",
    "YuMincho",
    "Hiragino Mincho ProN",
    "Hiragino Mincho Pro",
    "Noto Serif JP",
    serif;
  font-weight: 500;
}

/* サブ本文（開始しますの行） */
.medPopup__text{
  font-family:
    "Yu Mincho",
    "YuMincho",
    "Hiragino Mincho ProN",
    "Hiragino Mincho Pro",
    "Noto Serif JP",
    serif;
}