/* =========================================================================
   LOVEBU - Champagne Gold Theme  v2
   ========================================================================= */
:root {
  --gold-primary: #B8935A;
  --gold-deep: #8B6F3F;
  --gold-light: #D4B57E;
  --gold-pale: #E8D5B0;
  --marble-base: #F1E8D2;
  --marble-warm: #EBDFC2;
  --marble-cool: #E5D8B5;
  --cream-soft: #FAF6EC;
  --text-dark: #3D2E1F;
  --text-mid: #6B5A45;
  --text-muted: #9A8B72;
  --text-on-gold: #FFFFFF;
  --line-gold: rgba(184, 147, 90, 0.55);
  --line-gold-soft: rgba(184, 147, 90, 0.22);
  --shadow-card: 0 18px 50px rgba(139, 111, 63, 0.18);
  --shadow-button: 0 4px 14px rgba(139, 111, 63, 0.40);
  --grad-gold: linear-gradient(135deg, #E5C788 0%, #C9A368 30%, #A88445 70%, #8B6F3F 100%);
  --grad-gold-hov: linear-gradient(135deg, #EFD49A 0%, #D4B57E 50%, #A88445 100%);
  --font-display: 'Cormorant Garamond', 'Noto Serif JP', 'Times New Roman', serif;
  --font-body: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, sans-serif;
  --letter-wide: 0.18em;
}

/* body は単独セレクタだと .bg-primary に負けるので、両方カバーする */
body,
body.bg-primary {
  font-family: var(--font-body) !important;
  font-weight: 400 !important;
  color: var(--text-dark) !important;
  background-color: #F8F4ED !important;
  /* 本物の Calacatta Gold marble (Adobe Stock #287488092) */
  background-image: url("../../img/marble-bg.jpg") !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  background-attachment: fixed !important;
  min-height: 100vh;
  overflow-x: hidden !important;
}

/* モバイルでは軽量版を使う */
@media (max-width: 767.98px) {
  body, body.bg-primary {
    background-image: url("../../img/marble-bg-mobile.jpg") !important;
    /* iOSではfixedが安定しないのでscrollに */
    background-attachment: scroll !important;
  }
}

/* body::before は使わない（写真背景に直接） */
body::before {
  display: none !important;
}

body > * {
  position: relative;
  z-index: 1;
}

/* Bootstrap カラー上書き（body.bg-primary は除外＝上の宣言が効くようにする） */
:not(body).bg-primary {
  background-color: transparent !important;
  background-image: none !important;
}

.bg-dark, .bg-secondary, .bg-card-color {
  background-color: rgba(255,253,247,0.78) !important;
  color: var(--text-dark) !important;
}

.bg-light {
  background-color: rgba(255,253,247,0.65) !important;
}

.bg-lightgray {
  background-color: rgba(255,253,247,0.55) !important;
}

.bg-lightdark {
  background-color: rgba(184,147,90,0.12) !important;
  color: var(--text-dark) !important;
}

.bg-lightprimary {
  background-color: var(--gold-primary) !important;
}

.text-white {
  color: var(--text-dark) !important;
}

.text-dark {
  color: var(--text-dark) !important;
}

.text-gray {
  color: var(--text-muted) !important;
}

.text-primary {
  color: var(--gold-deep) !important;
}

.text-secondary {
  color: var(--text-mid) !important;
}

.border-primary {
  border-color: var(--gold-primary) !important;
}

.border {
  border-color: var(--line-gold) !important;
}

/* 出金画面の数字フォントとアイコンをゴールド系に */
.withdraw-input, .withdraw-money, .withdraw-rate, .without-lovepoint-now {
  color: var(--text-dark) !important;
}

.withdraw-input {
  border: 2px solid var(--gold-primary) !important;
  background-color: rgba(255,253,247,0.8) !important;
}
/* withdraw-icon-3, withdraw-icon-5 の青緑円アイコン背景を打ち消す */
img[src*="withdraw-icon"] {
  background-color: transparent !important;
}
/* ¥マーク等の青緑円画像はsepia系フィルタでゴールド寄りに */
img[src*="withdraw-icon-2"], img[src*="withdraw-icon-3"],
img[src*="withdraw-icon-4"], img[src*="withdraw-icon-5"] {
  filter: hue-rotate(170deg) saturate(0.6) brightness(1.1) sepia(0.5);
}

/* タイポ */
h1, h2, h3, h4, h5, .card-title {
  color: var(--text-dark) !important;
}

.card-title {
  font-family: var(--font-display) !important;
  font-weight: 500 !important;
  letter-spacing: var(--letter-wide);
  text-transform: uppercase;
  font-size: 1.35rem !important;
  color: var(--gold-deep) !important;
  border-bottom: 1px solid var(--line-gold-soft);
  padding-bottom: 0.6rem;
  margin-bottom: 1rem !important;
  display: flex !important;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.6rem;
}

  .card-title span {
    font-family: var(--font-body) !important;
    font-size: 0.78rem !important;
    letter-spacing: 0.08em;
    color: var(--text-mid) !important;
    text-transform: none;
    font-weight: 400 !important;
  }

.spTitle h1, .spTitleBox h1 {
  font-family: var(--font-display) !important;
  letter-spacing: 0.16em !important;
  color: var(--text-dark) !important;
  font-weight: 500 !important;
}

/* ヘッダー/フッター/サイドバー */
.header {
  background-color: rgba(255,253,247,0.85) !important;
  border-bottom: 1px solid var(--line-gold-soft);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

footer {
  background: transparent !important;
  border-top: 1px solid var(--line-gold-soft);
  padding: 1rem 0;
  height: auto !important;
}

  footer img {
    filter: sepia(1) saturate(2.2) hue-rotate(-12deg) brightness(0.72);
    opacity: 0.75;
    max-height: 36px;
  }

#sidebarMenu {
  background-color: var(--cream-soft) !important;
  background-image: radial-gradient(circle at 30% 20%, rgba(212,181,126,0.22) 0%, transparent 60%), linear-gradient(180deg, #FAF6EC 0%, #F0E5CD 100%) !important;
  border-right: 1px solid var(--line-gold-soft);
}

.sidebarMenuInner li {
  border-bottom: 1px solid var(--line-gold-soft);
  padding: 1rem 0.5rem;
  transition: background-color 0.2s ease;
}

  .sidebarMenuInner li:hover {
    background-color: rgba(184,147,90,0.10);
  }

.sidebarMenuInner a, .sidebarMenuInner a.text-white {
  color: var(--text-dark) !important;
  font-weight: 500;
}

  .sidebarMenuInner a span {
    color: var(--gold-deep) !important;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 0.85rem;
    letter-spacing: 0.06em;
  }

.sidebarLogo, [src*="LavepoLogo"], [src*="logo-green"], [src*="logo_lovepo"] {
  filter: sepia(1) saturate(2.5) hue-rotate(-15deg) brightness(0.78);
}

.sidebarIconToggle .spinner {
  background-color: var(--gold-deep) !important;
}

/* カード */
.card {
  background-color: rgba(255,253,247,0.78) !important;
  border: 1px solid var(--line-gold) !important;
  border-radius: 6px !important;
  box-shadow: var(--shadow-card);
  position: relative;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.loginBox .card,
.cardBox .card,
.cardBox2 .card {
  background-color: rgba(255,253,247,0.92) !important;
  border: 1px solid var(--gold-primary) !important;
  box-shadow: 0 0 0 6px rgba(255,253,247,0.5), 0 25px 70px rgba(139, 111, 63, 0.22);
}

@media (min-width: 768px) {
  .loginBox .card::before,
  .cardBox .card::before,
  .cardBox2 .card::before {
    content: "";
    position: absolute;
    inset: 8px;
    border: 1px solid var(--line-gold);
    border-radius: 4px;
    pointer-events: none;
  }
}

.loginBox, .cardBox {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem 0;
  width: 100%;
}

/* フォーム */
label {
  color: var(--text-mid) !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.06em;
  font-weight: 500 !important;
  margin-bottom: 0.4rem !important;
}

.loginBox label, .cardBox label {
  color: var(--text-mid) !important;
}

.form-control {
  /*  display: block !important;
  width: 100% !important;
  max-width: 100%;*/
  background-color: rgba(255,253,247,0.65) !important;
  border: 1px solid var(--line-gold-soft) !important;
  border-radius: 4px !important;
  color: var(--text-dark) !important;
  height: auto !important;
  padding: 0.7rem 1rem !important;
  transition: all 0.2s ease;
  box-shadow: inset 0 1px 2px rgba(139,111,63,0.04);
  font-weight: 400 !important;
}

  .form-control::placeholder {
    color: var(--text-muted) !important;
    opacity: 0.75;
  }

  .form-control:focus {
    background-color: rgba(255,253,247,0.95) !important;
    border-color: var(--gold-primary) !important;
    box-shadow: 0 0 0 3px rgba(184,147,90,0.15) !important;
    outline: none;
  }

select.form-control {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%238B6F3F' d='M6 8L0 0h12z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 10px 7px;
  padding-right: 36px !important;
  color: var(--text-dark) !important;
}

/* select 本体・option すべてダークブラウン文字に統一 */
select, select.form-control, select option {
  color: var(--text-dark) !important;
}

  select.changeSelect, .cardBox select, .loginBox select, .cardBox2 .changeSelect {
    color: var(--text-dark) !important;
    background-color: rgba(255,253,247,0.65) !important;
  }

/* selectBox の擬似要素矢印をゴールド化 */
.selectBox::before {
  border-top-color: var(--gold-deep) !important;
  border-right-color: var(--gold-deep) !important;
}

.no-data {
  color: var(--gold-deep) !important;
}

  .no-data::after {
    color: var(--gold-deep) !important;
  }

  .no-data + input,
  input.no-data {
    border-color: var(--gold-primary) !important;
    box-shadow: 0 0 2px 0.2rem rgba(184,147,90,0.30) !important;
  }

input[type="checkbox"] {
  accent-color: var(--gold-primary);
}

.loginBox input, .cardBox input {
  color: var(--text-dark) !important;
}

/* ボタン */
.loginBtn,
.btn-primary,
button[type="submit"],
.btn.btn-block {
  background: var(--grad-gold) !important;
  background-image: var(--grad-gold) !important;
  color: var(--text-on-gold) !important;
  border: none !important;
  border-radius: 4px !important;
  font-family: var(--font-body);
  font-weight: 600 !important;
  letter-spacing: 0.18em !important;
  padding: 0.95rem 1.5rem !important;
  box-shadow: var(--shadow-button), inset 0 1px 0 rgba(255,255,255,0.45), inset 0 -1px 0 rgba(0,0,0,0.10);
  transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease;
  text-shadow: 0 1px 1px rgba(139,111,63,0.5);
  text-decoration: none !important;
  text-align: center;
}
  /* btn-block は Bootstrap が width:100% をくれるので、追加指定不要 */
  .loginBtn:hover, .btn-primary:hover, button[type="submit"]:hover {
    transform: translateY(-1px);
    background-image: var(--grad-gold-hov) !important;
    color: var(--text-on-gold) !important;
  }

  /* 透明インラインstyle のアウトラインボタン */
  .loginBtn[style*="transparent"],
  .btn[style*="transparent"] {
    background: transparent !important;
    background-image: none !important;
    border: 1.5px solid var(--gold-primary) !important;
    color: var(--gold-deep) !important;
    text-shadow: none !important;
    box-shadow: none !important;
  }

    .loginBtn[style*="transparent"]:hover,
    .btn[style*="transparent"]:hover {
      background: rgba(184,147,90,0.08) !important;
      color: var(--gold-deep) !important;
      transform: none;
    }

.bg-white.text-primary,
.bg-white.text-primary:hover {
  background: var(--grad-gold) !important;
  color: var(--text-on-gold) !important;
}

.linkCopyBtn {
  background: var(--grad-gold) !important;
  color: var(--text-on-gold) !important;
  padding: 0.55rem 1.2rem !important;
  border-radius: 4px;
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  display: inline-block;
  text-decoration: none !important;
  box-shadow: var(--shadow-button);
  font-weight: 500;
}

  .linkCopyBtn:hover {
    color: #fff !important;
    text-decoration: none;
    transform: translateY(-1px);
  }

/* テーブル */
.table {
  color: var(--text-dark) !important;
  background-color: transparent;
}

.table-striped tbody tr:nth-of-type(odd) {
  background-color: rgba(184,147,90,0.05);
}

.table td, .table th {
  border-color: var(--line-gold-soft) !important;
}

.table thead th {
  color: var(--gold-deep) !important;
  font-family: var(--font-display);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--line-gold) !important;
}

.introduceTable td {
  color: var(--text-dark) !important;
  font-size: 0.85rem;
}

/* ポイント等 */
.lovePointText {
  font-family: var(--font-display);
  font-size: 2.6rem !important;
  color: var(--gold-deep) !important;
  letter-spacing: 0.04em;
  font-weight: 500;
}

.statesCard {
  background: linear-gradient(135deg, rgba(255,253,247,0.92), rgba(245,230,200,0.92)) !important;
  border: 1px solid var(--gold-primary) !important;
}

.statesCardContent {
  padding: 1rem 0;
}

.partneerQrCode {
  background: #fff !important;
  padding: 6px;
  border: 1px solid var(--line-gold);
  border-radius: 4px;
}

.partnerTypeLink, .partnerTypeLink.text-white {
  color: var(--gold-deep) !important;
  word-break: break-all;
}

.partnerTypeText {
  color: var(--text-mid) !important;
  font-size: 0.85rem;
}

.acountName, .acountName.text-secondary {
  color: var(--text-dark) !important;
  font-weight: 500;
}

.acountImg {
  border: 2px solid var(--gold-primary);
  border-radius: 50%;
  padding: 2px;
  background: #fff;
}

/* ネストされた dark/secondary カード */
.card .card.bg-dark, .card .card.bg-secondary {
  background-color: rgba(255,253,247,0.65) !important;
  border: 1px solid var(--line-gold-soft) !important;
}

  .card .card.bg-dark .text-white, .card .card.bg-secondary .text-white {
    color: var(--text-dark) !important;
  }

/* 設定の「変更する」ボタンをゴールドグラデに */
.setting-form-change-btn {
  background: var(--grad-gold) !important;
  color: var(--text-on-gold) !important;
  border-radius: 2rem !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.08em !important;
  border: none !important;
  box-shadow: 0 2px 8px rgba(139,111,63,0.25);
}

  .setting-form-change-btn:hover {
    background: var(--grad-gold-hov) !important;
    color: var(--text-on-gold) !important;
  }

/* メール通知などのトグルボタン（円形ON/OFFインジケーター）の青を打ち消す */
[class*="custom-control"] .custom-control-input:checked ~ .custom-control-label::before,
.custom-control-input:checked ~ .custom-control-label::before {
  background-color: var(--gold-primary) !important;
  border-color: var(--gold-deep) !important;
}

/* 現在ページを示す青系の丸（lovePoint/setting/list内のドットや丸） */
[style*="background:#017A84"], [style*="background: #017A84"],
[style*="background:#00B5AF"], [style*="background: #00B5AF"],
[style*="background:#0093BF"], [style*="background: #0093BF"],
[style*="background-color:#017A84"], [style*="background-color: #017A84"] {
  background-color: var(--gold-primary) !important;
  background-image: none !important;
}

/* "Introducer"バッジ（紹介種別の色） */
.introducerBadge,
[style*="#1FAFA0"],
[style*="#00A5B8"] {
  background-color: var(--gold-pale) !important;
  color: var(--gold-deep) !important;
}

/* トグルスイッチの ON 色（シアン #00c4cc）をゴールドに */
.switch__input:checked ~ .switch__content:after,
.switch__input:checked + .switch__content:after {
  background-color: var(--gold-primary) !important;
}

.switch__circle {
  background-color: #fff !important;
  box-shadow: 0 2px 6px rgba(139,111,63,0.35) !important;
}

/* トグルの背景帯の青を解除 */
.switch__content {
  background-color: rgba(184,147,90,0.18) !important;
}

.switch__input:checked ~ .switch__content,
.switch__input:checked + .switch__content {
  background-color: var(--gold-primary) !important;
}

/* ロールバッジ系（紹介リストの色付きバッジ）以外 - ステータスドット */
.dot-online, .status-dot, .led-blue {
  background-color: var(--gold-primary) !important;
}

/* loverpointのドット（青い丸印）もゴールドに */
.lovePointDot, [class*="bg-info"], .bg-info {
  background-color: var(--gold-primary) !important;
}

/* search button 旧シアン */
.searchBtn {
  background: var(--grad-gold) !important;
  color: var(--text-on-gold) !important;
  border: none !important;
}

/* SP用タイトルバー（margin: 0 -1rem を打ち消し、見切れ防止） */
.spTitleBox {
  background-color: rgba(255,253,247,0.78) !important;
  border-bottom: 1px solid var(--line-gold);
  padding: 1.6rem 1.2rem !important;
  margin: 0 !important;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

  .spTitleBox h1 {
    color: var(--text-dark) !important;
    font-family: var(--font-display) !important;
    font-weight: 500 !important;
    letter-spacing: 0.16em !important;
    font-size: 1.5rem !important;
    margin: 0;
  }

/* SPでのpadding緩和 */
@media (max-width: 767.98px) {
  .loginBox .card, .cardBox .card {
    padding: 1.5rem 1rem !important;
  }

  .card-title {
    font-size: 1.2rem !important;
  }

  .lovePointText {
    font-size: 2.2rem !important;
  }

  .loginBox .col-12, .cardBox .col-12 {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }

  .loginBox .col-11, .cardBox .col-11 {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
}

/* リンク */
a, a.text-white {
  color: var(--gold-deep) !important;
}

  a:hover {
    color: var(--gold-primary) !important;
    text-decoration: none;
  }

hr {
  border-top-color: var(--line-gold-soft) !important;
}

/* スクロールバー */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: rgba(184,147,90,0.06);
}

::-webkit-scrollbar-thumb {
  background: var(--gold-light);
  border-radius: 4px;
}

  ::-webkit-scrollbar-thumb:hover {
    background: var(--gold-primary);
  }
