/* 口コミ（レビュー）機能 スタイル
   テーマの rem スケールに準拠（1rem = 100px / vw可変, base.css）。
   フォントサイズは clamp() で可変、配色は :root 変数（--gold 等）を使用。 */

/* ===== 共通：星表示 ===== */
.review-stars {
  letter-spacing: 0.02rem;
  color: var(--gold, #c19b5b);
  font-size: clamp(.16rem, 3.2vw, .2rem);
  white-space: nowrap;
}
.review-stars .star-empty {
  color: #d8cdba;
}

/* ===== プロフィールページ内 Reviews セクション ===== */
#companion_reviews.reviews-section {
  margin: .6rem auto;
  text-align: left;
  scroll-margin-top: 100px; /* 固定ヘッダー分のアンカーオフセット */
}

/* コンパニオンカード内の口コミ★・件数（クリックでプロフィール内レビューへ） */
.companion-card .card-reviews {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin: 4px 0 2px;
  text-decoration: none;
  line-height: 1;
}
.companion-card .card-reviews .review-stars {
  font-size: 14px;
  letter-spacing: 1px;
}
.companion-card .card-reviews__score {
  font-size: 13px;
  font-weight: 700;
  color: var(--gold, #c19b5b);
}
.companion-card .card-reviews__count {
  font-size: 12px;
  color: #8a8175;
}
#companion_reviews .reviews-empty {
  text-align: center;
  color: #8a8175;
  font-size: clamp(.14rem, 2.6vw, .18rem);
  padding: .3rem 0;
}
/* 「Write a Review」ボタン */
.reviews-action {
  text-align: center;
  margin-top: .3rem;
}
.review-open-btn {
  display: inline-block;
  background: transparent;
  color: var(--gold, #c19b5b);
  border: 1px solid var(--gold, #c19b5b);
  border-radius: .04rem;
  padding: .12rem .4rem;
  font-size: clamp(.14rem, 2.6vw, .17rem);
  font-family: var(--font-button, 'EB Garamond', serif);
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.review-open-btn:hover {
  background: var(--gold, #c19b5b);
  color: #fff;
}

/* サマリー（平均・件数） */
/* REVIEWS見出し＋サマリーを1行に */
#companion_reviews .reviews-header {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: .08rem .2rem;
  margin-bottom: .24rem;
}
#companion_reviews .reviews-header .subttl {
  margin: 0;
  width: auto;
}
#companion_reviews .reviews-summary {
  display: flex;
  align-items: baseline;
  gap: .1rem;
  flex-wrap: nowrap;
  margin: 0;
}
#companion_reviews .reviews-average {
  font-family: var(--font-heading, 'Bodoni Moda', serif);
  font-size: clamp(.16rem, 3vw, .2rem);
  font-weight: 700;
  color: var(--gold, #c19b5b);
  line-height: 1;
}
#companion_reviews .reviews-count {
  font-size: clamp(.12rem, 2.2vw, .14rem);
  color: #8a8175;
  white-space: nowrap;
}

/* 口コミ一覧（プロフィール内・一覧ページ共通の見た目） */
.reviews-list {
  list-style: none;
  margin: 0 0 .2rem;
  padding: 0;
}
/* 一覧ページ（/reviews/）用の行 */
.review-item {
  border-top: 1px solid #e7ddca;
  padding: .16rem 0;
}

/* ===== プロフィール内：レビューカード（3〜4カラムのグリッド） ===== */
#reviews-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  align-items: stretch;
}
.review-card {
  display: flex;
  flex-direction: column;
  border: 1px solid #ece4d4;
  border-radius: 8px;
  background: #fff;
  padding: 14px 16px;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(0, 0, 0, .06);
  transition: box-shadow .15s, transform .15s, border-color .15s;
}
.review-card:hover,
.review-card:focus-visible {
  border-color: var(--lightgold, #d3b78e);
  box-shadow: 0 6px 18px rgba(0, 0, 0, .12);
  transform: translateY(-2px);
  outline: none;
}
.review-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
/* カード内はpx固定で可読性を担保（rem(vw連動)だとモバイルで極小になるため） */
.review-card .review-name {
  font-size: 15px;
}
.review-card .review-stars {
  font-size: 15px;
}
.review-card .review-date,
.review-card .review-used {
  font-size: 12px;
}
.review-card .review-comment {
  font-size: 14px;
  line-height: 1.65;
  margin-top: 6px;
}
/* コメントのクランプ表示（カードは3行） */
.review-comment.is-clamped {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.review-card .review-comment.is-clamped {
  -webkit-line-clamp: 3;
}
.review-readmore {
  display: inline-block;
  margin-top: auto;
  padding-top: 8px;
  color: var(--gold, #c19b5b);
  font-size: 13px;
  font-family: var(--font-button, 'EB Garamond', serif);
}
.review-readmore[hidden] {
  display: none;
}

/* ===== 全文表示モーダルの中身 ===== */
.review-detail__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .12rem;
  margin-bottom: .04rem;
}
.review-detail-name {
  font-family: var(--font-heading, 'Bodoni Moda', serif);
  font-weight: 700;
  font-size: 18px;
}
.review-detail-date {
  display: block;
  font-size: 12px;
  color: #aaa097;
}
.review-detail-used {
  display: block;
  font-size: 12px;
  color: #b39656;
  margin-bottom: 10px;
}
.review-detail-comment {
  font-size: 15px;
  line-height: 1.8;
  white-space: pre-line;
  margin-top: 12px;
}
.review-detail-reply:not(:empty) {
  margin-top: .16rem;
  padding: .14rem .16rem;
  background: var(--whitegold, #f8f3eb);
  border-left: 3px solid var(--gold, #c19b5b);
}
/* もっと読み込む */
.reviews-loadmore-wrap {
  text-align: center;
  margin-top: .24rem;
}
.reviews-loadmore {
  background: transparent;
  color: var(--gold, #c19b5b);
  border: 1px solid var(--gold, #c19b5b);
  border-radius: .04rem;
  padding: .08rem .3rem;
  font-size: clamp(.13rem, 2.4vw, .16rem);
  font-family: var(--font-button, 'EB Garamond', serif);
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.reviews-loadmore:hover {
  background: var(--gold, #c19b5b);
  color: #fff;
}
.reviews-loadmore:disabled {
  opacity: 0.6;
  cursor: default;
}
.review-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .12rem;
}
.review-name {
  font-family: var(--font-heading, 'Bodoni Moda', serif);
  font-weight: 700;
  font-size: clamp(.16rem, 3vw, .19rem);
}
.review-cast-link {
  color: var(--gold, #c19b5b);
  text-decoration: none;
}
.review-date {
  display: block;
  font-size: clamp(.11rem, 2.2vw, .14rem);
  color: #aaa097;
  margin: .03rem 0 .02rem;
}
.review-used {
  display: block;
  font-size: clamp(.11rem, 2.2vw, .14rem);
  color: #b39656;
  margin: 0 0 .1rem;
}
.review-comment {
  margin: 0;
  font-size: clamp(.14rem, 2.6vw, .18rem);
  line-height: 1.7;
  white-space: pre-line;
}

/* 店舗からの返信 */
.review-reply {
  margin-top: .14rem;
  padding: .14rem .16rem;
  background: var(--whitegold, #f8f3eb);
  border-left: 3px solid var(--gold, #c19b5b);
}
.review-reply-label {
  display: block;
  font-size: clamp(.12rem, 2.2vw, .14rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--gold, #c19b5b);
  margin-bottom: .06rem;
}
.review-reply-text {
  margin: 0;
  font-size: clamp(.13rem, 2.4vw, .17rem);
  line-height: 1.6;
  white-space: pre-line;
}

.reviews-viewall {
  text-align: right;
  margin: .12rem 0 0;
}
.reviews-viewall a {
  font-size: clamp(.13rem, 2.4vw, .16rem);
  color: var(--gold, #c19b5b);
  text-decoration: none;
}

/* ===== 投稿モーダル ===== */
.mirai-review-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: .32rem;
  z-index: 12000;
}
.mirai-review-modal.is-active {
  display: flex;
}
.mirai-review-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .6);
}
.mirai-review-modal__dialog {
  position: relative;
  z-index: 1;
  background: var(--white, #fff);
  border-radius: .2rem;
  width: 100%;
  max-width: 5.2rem;
  max-height: 90vh;
  overflow-y: auto;
  padding: .5rem .42rem;
  box-shadow: 0 .3rem .8rem rgba(0, 0, 0, .25);
  outline: none;
}
.mirai-review-modal__close {
  position: absolute;
  top: .14rem;
  right: .2rem;
  width: .42rem;
  height: .42rem;
  border: none;
  background: transparent;
  font-size: .36rem;
  line-height: 1;
  cursor: pointer;
  color: var(--black, #000);
}
.mirai-review-modal__title {
  font-family: var(--font-heading, 'Bodoni Moda', serif);
  font-size: clamp(.22rem, 4vw, .3rem);
  text-align: center;
  margin: 0 0 .06rem;
}
.mirai-review-modal__cast {
  text-align: center;
  margin: 0 0 .3rem;
  font-size: clamp(.14rem, 2.6vw, .17rem);
  color: #8a8175;
  letter-spacing: 0.02em;
}
.mirai-review-modal__cast span {
  color: var(--gold, #c19b5b);
  font-weight: 700;
}
body.mirai-review-open {
  overflow: hidden;
}

/* ===== 投稿フォーム（モーダル内） ===== */
.review-field {
  display: block;
  margin-bottom: .2rem;
}
.review-label {
  display: block;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 6px;
}
.review-label em {
  color: #c0392b;
  font-style: normal;
}
/* モーダル内フォームはpxで固定（iOSの自動ズーム防止＝16px以上、可読性確保） */
.review-field textarea,
.review-field input[type="text"],
.review-field input[type="date"] {
  width: 100%;
  padding: 11px 12px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 16px;
  line-height: 1.4;
  font-family: var(--font-basic, 'EB Garamond', serif);
  box-sizing: border-box;
  background: #fff;
  color: #333;
}
/* iOSで日付入力が潰れて見えないのを防ぐ */
.review-field input[type="date"] {
  min-height: 46px;
  -webkit-appearance: none;
  appearance: none;
}

/* 星評価入力 */
.review-rating-input {
  display: inline-flex;
  gap: .04rem;
}
.rating-star {
  background: none;
  border: none;
  cursor: pointer;
  font-size: clamp(.3rem, 6vw, .42rem);
  line-height: 1;
  color: var(--gold, #c19b5b);
  padding: 0;
  transition: transform .1s;
}
.rating-star:hover {
  transform: scale(1.1);
}

.review-submit-btn {
  width: 100%;
  background: var(--gold, #c19b5b);
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 13px 24px;
  font-size: 16px;
  font-family: var(--font-button, 'EB Garamond', serif);
  letter-spacing: 0.06em;
  cursor: pointer;
  margin-top: 8px;
}
.review-submit-btn:disabled {
  opacity: 0.6;
  cursor: default;
}

/* ===== 確認ステップ ===== */
.review-confirm[hidden] {
  display: none;
}
.review-confirm-note {
  margin: 0 0 16px;
  font-size: 14px;
  line-height: 1.6;
  text-align: center;
  color: #8a8175;
}
.review-confirm-note strong {
  color: #c0392b;
}
.review-confirm-preview {
  margin: 0 0 .24rem;
  border: 1px solid #e7ddca;
  border-radius: .04rem;
  padding: .16rem .2rem;
}
.review-confirm-preview dt {
  font-size: 12px;
  font-weight: 700;
  color: #8a8175;
  margin-top: 12px;
}
.review-confirm-preview dt:first-child {
  margin-top: 0;
}
.review-confirm-preview dd {
  margin: 4px 0 0;
  font-size: 15px;
  line-height: 1.6;
  white-space: pre-line;
  word-break: break-word;
}
.review-confirm-actions {
  display: flex;
  gap: .16rem;
}
.review-back-btn,
.review-confirm-btn {
  flex: 1;
  border-radius: 4px;
  padding: 13px 16px;
  font-size: 16px;
  font-family: var(--font-button, 'EB Garamond', serif);
  letter-spacing: 0.06em;
  cursor: pointer;
}
.review-back-btn {
  background: #fff;
  color: #8a8175;
  border: 1px solid #ccc;
}
.review-confirm-btn {
  background: var(--gold, #c19b5b);
  color: #fff;
  border: none;
}
.review-confirm-btn:disabled,
.review-back-btn:disabled {
  opacity: 0.6;
  cursor: default;
}

.review-form-msg {
  margin: 8px 0;
  font-size: 14px;
}
.review-form-msg.is-error {
  color: #c0392b;
}
.review-form-msg.is-success {
  color: #2e7d32;
}

/* ===== 口コミ一覧ページ（/reviews/）固有 ===== */
.reviews-filter {
  display: flex;
  gap: .24rem;
  flex-wrap: wrap;
  margin-bottom: .24rem;
  font-size: clamp(.13rem, 2.4vw, .16rem);
}
.reviews-filter select {
  font-size: clamp(.13rem, 2.4vw, .16rem);
  padding: .04rem .08rem;
}
.reviews-empty {
  font-size: clamp(.14rem, 2.6vw, .18rem);
  color: #8a8175;
}
.reviews-pagination {
  display: flex;
  gap: .1rem;
  justify-content: center;
  align-items: center;
  margin-top: .3rem;
  font-size: clamp(.13rem, 2.4vw, .16rem);
}
.reviews-pagination a,
.reviews-pagination span {
  padding: .04rem .1rem;
  text-decoration: none;
  color: #333;
}
.reviews-pagination a {
  color: var(--gold, #c19b5b);
}
.reviews-pagination .is-current {
  font-weight: 700;
  border-bottom: 2px solid var(--gold, #c19b5b);
}

/* ===== スタッフポータル（管理画面） ===== */
.staff-portal-wrap {
  max-width: 10.3rem;
  margin: .6rem auto;
  padding: 0 .16rem;
  font-size: clamp(.14rem, 2.4vw, .17rem);
}
.staff-portal-wrap .subpage_subttl_txt {
  font-family: var(--font-heading, 'Bodoni Moda', serif);
  font-size: clamp(.2rem, 4vw, .28rem);
  margin-bottom: .2rem;
}
.staff-portal-wrap .lead_txt {
  font-size: clamp(.13rem, 2.4vw, .16rem);
  color: #8a8175;
  margin-bottom: .24rem;
}
.staff-nav {
  display: flex;
  gap: .2rem;
  border-bottom: 2px solid var(--gold, #c19b5b);
  margin-bottom: .3rem;
  padding-bottom: .1rem;
  font-size: clamp(.14rem, 2.6vw, .17rem);
}
.staff-nav a {
  text-decoration: none;
  color: #333;
  font-weight: 700;
}
.staff-nav a.is-current {
  color: var(--gold, #c19b5b);
}
.staff-table {
  width: 100%;
  border-collapse: collapse;
  font-size: clamp(.12rem, 2.2vw, .15rem);
}
.staff-table th,
.staff-table td {
  border: 1px solid #ddd;
  padding: .08rem .1rem;
  text-align: left;
  vertical-align: top;
}
.staff-table th {
  background: var(--whitegold, #f8f3eb);
  white-space: nowrap;
}
/* コメント列は全文表示（折り返し） */
.staff-col-comment {
  min-width: 2.2rem;
  max-width: 4rem;
  white-space: normal;
  word-break: break-word;
  line-height: 1.6;
}

/* 返信画面の口コミ詳細 */
.staff-review-detail {
  margin: 0 0 .3rem;
  border: 1px solid #e7ddca;
  border-radius: .04rem;
  padding: .16rem .2rem;
}
.staff-review-detail dt {
  font-size: clamp(.12rem, 2.2vw, .14rem);
  font-weight: 700;
  color: #8a8175;
  margin-top: .12rem;
}
.staff-review-detail dt:first-child {
  margin-top: 0;
}
.staff-review-detail dd {
  margin: .03rem 0 0;
  font-size: clamp(.14rem, 2.4vw, .16rem);
}
.staff-review-detail .staff-review-comment {
  white-space: pre-line;
  line-height: 1.7;
}
.staff-filter {
  display: flex;
  gap: .24rem;
  flex-wrap: wrap;
  margin-bottom: .24rem;
  font-size: clamp(.13rem, 2.4vw, .16rem);
}
.staff-form-field {
  margin-bottom: .2rem;
}
.staff-form-field label {
  display: block;
  font-weight: 700;
  margin-bottom: .06rem;
  font-size: clamp(.13rem, 2.4vw, .16rem);
}
.staff-form-field input[type="text"],
.staff-form-field input[type="password"],
.staff-form-field input[type="number"],
.staff-form-field input[type="datetime-local"],
.staff-form-field select,
.staff-form-field textarea {
  width: 100%;
  max-width: 5rem;
  padding: .08rem .1rem;
  border: 1px solid #ccc;
  border-radius: .04rem;
  font-size: clamp(.14rem, 2.4vw, .16rem);
  font-family: var(--font-basic, 'EB Garamond', serif);
  box-sizing: border-box;
}
.staff-btn {
  display: inline-block;
  background: var(--gold, #c19b5b);
  color: #fff;
  border: none;
  border-radius: .04rem;
  padding: .07rem .2rem;
  cursor: pointer;
  font-size: clamp(.12rem, 2.2vw, .15rem);
  text-decoration: none;
  line-height: 1.6;
}
.staff-btn-sub {
  background: #8a8175;
}
.staff-btn-danger {
  background: #c0392b;
}
.staff-msg {
  padding: .1rem .14rem;
  border-radius: .04rem;
  margin-bottom: .2rem;
  font-size: clamp(.13rem, 2.4vw, .16rem);
}
.staff-msg.is-success {
  background: #e8f5e9;
  color: #2e7d32;
}
.staff-msg.is-error {
  background: #fdecea;
  color: #c0392b;
}
.staff-status-published {
  color: #2e7d32;
  font-weight: 700;
}
.staff-status-pending {
  color: #b8860b;
  font-weight: 700;
}
/* 操作セルは table-cell のまま。中のボタンを inline-block で折り返す */
.staff-actions {
  min-width: 96px;
}
.staff-actions form {
  display: inline-block;
  margin: 0 4px 6px 0;
  vertical-align: top;
}
.staff-actions > a.staff-btn {
  margin: 0 4px 6px 0;
  vertical-align: top;
}
.staff-login-form {
  max-width: 4.2rem;
}

/* ===== 検索可能なキャスト選択（Select2） ===== */
.staff-filter__group {
  display: inline-flex;
  align-items: center;
  gap: .08rem;
}
/* JS無効時 / Select2初期化前の素のセレクト */
.cast-select {
  max-width: 5rem;
  padding: .08rem .1rem;
  border: 1px solid #ccc;
  border-radius: .04rem;
  font-size: clamp(.13rem, 2.4vw, .16rem);
}
.staff-filter__group .cast-select {
  max-width: 3.2rem;
}

/* Select2 のサイズ・配色をテーマに寄せる（Select2はpxベース） */
.select2-container {
  min-width: 220px;
  max-width: 100%;
  vertical-align: middle;
}
.staff-form-field .select2-container {
  width: 100% !important;
  max-width: 480px;
}
.select2-container--default .select2-selection--single {
  height: 36px;
  border-color: #ccc;
  border-radius: 4px;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 34px;
  font-size: 14px;
  color: #333;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 34px;
}
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
  border-color: var(--gold, #c19b5b);
  outline: none;
}
.select2-dropdown {
  border-color: var(--gold, #c19b5b);
  font-size: 14px;
}
.select2-search--dropdown .select2-search__field {
  font-size: 14px;
  padding: 6px 8px;
}
.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background-color: var(--gold, #c19b5b);
}
.select2-container--default .select2-results__option[aria-selected="true"] {
  background-color: var(--whitegold, #f8f3eb);
  color: var(--gold, #c19b5b);
}
