/* ============================================================
   Sinc 共通スタイル
   ライトモードデフォルト / ダークモードは [data-theme="dark"]
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Noto+Sans+JP:wght@400;500;700;900&display=swap');

/* --- リセット & CSS変数 --- */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  /* ライトモード（デフォルト） */
  --bg:#ffffff;
  --surface:#f7f9fb;
  --surface2:#eff3f4;
  --surface3:#dce3e8;
  --accent:#6c5ce7;
  --accent2:#5a4bd1;
  --pink:#e84393;
  --text:#0f1419;
  --text2:#536471;
  --success:#00a86b;
  --warning:#d97706;
  --danger:#c0392b;
  --radius:14px;
  --shadow:0 4px 24px rgba(0,0,0,.08);
  /* ファミリーカラー */
  --fam-architects:108,92,231;
  --fam-mystics:232,67,147;
  --fam-commanders:0,168,107;
  --fam-catalysts:217,119,6;
}
html,body{
  height:100%;
  font-family:'Inter','Noto Sans JP',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-tap-highlight-color:transparent;
  -webkit-text-size-adjust:100%;
  touch-action:manipulation;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:var(--accent2);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent)}

/* --- アニメーション --- */
@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeOut{from{opacity:1}to{opacity:0}}
@keyframes slideIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* --- レイアウト --- */
.page{
  min-height:100vh;min-height:100dvh;
  padding:20px;
  padding-top:env(safe-area-inset-top,20px);
  padding-bottom:env(safe-area-inset-bottom,20px);
  animation:fadeIn .5s ease;
}
.container{
  width:100%;
  max-width:640px;
  margin:0 auto;
}

/* --- ナビゲーションバー --- */
.nav-bar{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--surface);
  border-top:1px solid var(--surface3);
  display:flex;align-items:center;
  padding:8px 0;
  padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));
  z-index:100;
}
.nav-item{
  flex:1;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:6px 0;
  color:var(--text2);
  font-size:.65rem;
  text-decoration:none;
  transition:color .2s;
  cursor:pointer;
  border:none;background:none;
}
.nav-item:hover,.nav-item.active{color:var(--accent2)}
.nav-icon{font-size:1.3rem;line-height:1}

/* ナビバー分のpadding */
.page{padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}

/* --- ヘッダー --- */
.page-header{
  display:flex;align-items:center;gap:12px;
  margin-bottom:24px;
}
.page-header .back-btn{
  width:36px;height:36px;
  border:1px solid var(--surface3);border-radius:50%;
  background:var(--surface);color:var(--text2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1rem;transition:all .2s;
  flex-shrink:0;
}
.page-header .back-btn:hover{border-color:var(--accent);color:var(--text)}
.page-title{font-size:1.15rem;font-weight:700;letter-spacing:-.02em}
.page-subtitle{font-size:.8rem;color:var(--text2);margin-top:2px}

/* --- カード --- */
.card{
  background:var(--surface);
  border:1px solid var(--surface3);
  border-radius:var(--radius);
  padding:20px;
  margin-bottom:12px;
  transition:border-color .2s,box-shadow .2s;
}
.card:hover{border-color:rgba(108,92,231,.3);box-shadow:0 4px 16px rgba(108,92,231,.07)}
.card-clickable{cursor:pointer}

/* --- ボタン --- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:12px 28px;
  font-size:.9rem;font-weight:600;
  border:none;border-radius:50px;
  cursor:pointer;
  transition:all .3s;
  -webkit-appearance:none;
  touch-action:manipulation;
}
.btn-primary{
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;
  box-shadow:0 4px 20px rgba(108,92,231,.3);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(108,92,231,.5)}
.btn-primary:active{transform:translateY(0)}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}

.btn-secondary{
  background:transparent;
  border:1px solid var(--surface3);
  color:var(--text2);
}
.btn-secondary:hover{border-color:var(--accent);color:var(--text)}

.btn-danger{
  background:transparent;
  border:1px solid rgba(225,112,85,.3);
  color:var(--danger);
}
.btn-danger:hover{background:rgba(225,112,85,.1);border-color:var(--danger)}

.btn-sm{padding:8px 18px;font-size:.8rem}
.btn-block{width:100%;display:flex;align-items:center;justify-content:center}

/* --- 入力フォーム --- */
.form-group{margin-bottom:16px}
.form-label{
  display:block;
  font-size:.78rem;font-weight:600;
  color:var(--text2);
  margin-bottom:6px;
  letter-spacing:.04em;
}
.form-input{
  width:100%;
  padding:14px 16px;
  background:var(--surface2);
  border:1px solid var(--surface3);
  border-radius:10px;
  color:var(--text);
  font-size:.9rem;
  transition:border-color .2s,box-shadow .2s;
  outline:none;
  -webkit-appearance:none;
}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(108,92,231,.1)}
.form-input::placeholder{color:var(--text2);opacity:.6}
textarea.form-input{
  resize:vertical;
  min-height:100px;
  line-height:1.6;
  font-family:inherit;
}
.form-hint{font-size:.7rem;color:var(--text2);margin-top:4px}
.form-error{font-size:.75rem;color:var(--danger);margin-top:4px;display:none}
.form-error.show{display:block}

/* --- バッジ --- */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;
  border-radius:20px;
  font-size:.7rem;font-weight:600;
  border:1px solid;
}
.badge-architects{
  color:rgb(var(--fam-architects));
  border-color:rgba(var(--fam-architects),.3);
  background:rgba(var(--fam-architects),.08);
}
.badge-mystics{
  color:rgb(var(--fam-mystics));
  border-color:rgba(var(--fam-mystics),.3);
  background:rgba(var(--fam-mystics),.08);
}
.badge-commanders{
  color:rgb(var(--fam-commanders));
  border-color:rgba(var(--fam-commanders),.3);
  background:rgba(var(--fam-commanders),.08);
}
.badge-catalysts{
  color:rgb(var(--fam-catalysts));
  border-color:rgba(var(--fam-catalysts),.3);
  background:rgba(var(--fam-catalysts),.08);
}

/* --- タイプバッジ（投稿者表示用） --- */
.user-badge{
  display:flex;align-items:center;gap:8px;
}
.user-type-icon{
  width:32px;height:32px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;
  flex-shrink:0;
}
.user-info{display:flex;flex-direction:column;gap:1px}
.user-type-name{font-size:.78rem;font-weight:600;color:var(--text)}
.user-display-id{font-size:.68rem;color:var(--text2)}

/* --- 投稿番号・レス・メンション --- */
.post-num{
  font-size:.68rem;font-weight:700;
  color:var(--text2);
  background:var(--surface2);
  border:1px solid var(--surface3);
  border-radius:4px;
  padding:1px 6px;
  cursor:default;
  font-family:monospace;
}
.post-ref{
  color:var(--accent2);
  font-weight:700;
  text-decoration:none;
  font-size:.88rem;
}
.post-ref:hover{text-decoration:underline;color:var(--accent)}
.post-mention{
  color:var(--pink);
  font-weight:700;
}
.post-reply-to{
  font-size:.75rem;color:var(--text2);
  margin-bottom:6px;
  padding:4px 8px;
  border-left:2px solid var(--surface3);
  border-radius:0 4px 4px 0;
}

/* --- 投稿カード --- */
.post-card{
  background:var(--surface);
  border:1px solid var(--surface3);
  border-radius:var(--radius);
  padding:16px;
  margin-bottom:12px;
  animation:fadeIn .3s ease;
}
.post-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:10px;
}
.post-content{
  font-size:.88rem;
  line-height:1.75;
  color:var(--text);
  margin-bottom:12px;
  word-break:break-word;
}
.post-actions{
  display:flex;align-items:center;gap:16px;
  font-size:.75rem;color:var(--text2);
}
.post-action{
  display:flex;align-items:center;gap:4px;
  cursor:pointer;
  border:none;background:none;color:var(--text2);
  padding:4px 0;
  transition:color .2s;
}
.post-action:hover{color:var(--accent2)}
.post-action.liked{color:var(--pink)}
.post-time{font-size:.7rem;color:var(--text2);margin-left:auto}

/* --- スレッド一覧 --- */
.thread-item{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 16px;
  background:var(--surface);
  border:1px solid var(--surface3);
  border-radius:var(--radius);
  margin-bottom:8px;
  cursor:pointer;
  transition:border-color .2s;
  text-decoration:none;
  color:var(--text);
}
.thread-item:hover{border-color:rgba(108,92,231,.3)}
.thread-icon{font-size:1.2rem;margin-top:2px;flex-shrink:0}
.thread-body{flex:1;min-width:0}
.thread-title{font-size:.9rem;font-weight:600;margin-bottom:4px;line-height:1.55}
.thread-meta{font-size:.72rem;color:var(--text2);display:flex;align-items:center;gap:10px}
.thread-pinned{color:var(--warning);font-weight:600}
.thread-locked{color:var(--text2);opacity:.6}

/* --- 板カード（掲示板トップ用） --- */
.board-card{
  display:flex;align-items:center;gap:14px;
  padding:16px 18px;
  background:var(--surface);
  border:1px solid var(--surface3);
  border-radius:var(--radius);
  margin-bottom:10px;
  cursor:pointer;
  transition:all .2s;
  text-decoration:none;color:var(--text);
}
.board-card:hover{border-color:rgba(108,92,231,.3);transform:translateX(4px)}
.board-icon{font-size:1.6rem;flex-shrink:0;width:44px;text-align:center}
.board-info{flex:1;min-width:0}
.board-name{font-size:.92rem;font-weight:700;margin-bottom:3px}
.board-desc{font-size:.75rem;color:var(--text2);line-height:1.55}
.board-arrow{color:var(--text2);font-size:1rem;flex-shrink:0}

/* --- ローディング --- */
.loading{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:40px 0;
  color:var(--text2);
  gap:12px;
}
.spinner{
  width:32px;height:32px;
  border:3px solid var(--surface3);
  border-top-color:var(--accent);
  border-radius:50%;
  animation:spin .8s linear infinite;
}

/* --- 空状態 --- */
.empty-state{
  text-align:center;
  padding:40px 20px;
  color:var(--text2);
}
.empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:.65}
.empty-text{font-size:.88rem;line-height:1.6}

/* --- モーダル --- */
.modal-overlay{
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(0,0,0,.7);
  display:none;align-items:center;justify-content:center;
  z-index:200;
  padding:20px;
  animation:fadeIn .2s ease;
}
.modal-overlay.show{display:flex}
.modal{
  background:var(--surface);
  border:1px solid var(--surface3);
  border-radius:20px;
  padding:28px;
  width:100%;max-width:480px;
  max-height:90vh;overflow-y:auto;
  animation:fadeIn .3s ease;
  box-shadow:0 20px 60px rgba(0,0,0,.15);
}
.modal-title{font-size:1rem;font-weight:700;margin-bottom:16px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;align-items:center;margin-top:20px}

/* --- トースト通知 --- */
.toast{
  position:fixed;bottom:100px;left:50%;transform:translateX(-50%);
  background:var(--surface2);
  border:1px solid var(--surface3);
  border-radius:50px;
  padding:10px 24px;
  font-size:.82rem;
  color:var(--text);
  box-shadow:var(--shadow);
  z-index:300;
  animation:fadeIn .3s ease;
  pointer-events:none;
}
.toast.success{border-color:rgba(0,184,148,.4);color:var(--success)}
.toast.error{border-color:rgba(225,112,85,.4);color:var(--danger)}

/* --- セクション見出し --- */
.section-title{
  font-size:.8rem;
  font-weight:700;
  color:var(--text2);
  letter-spacing:.06em;
  text-transform:uppercase;
  margin-bottom:14px;
  padding-left:10px;
  border-left:2px solid var(--accent);
}

/* --- タブ --- */
.tabs{
  display:flex;gap:4px;align-items:center;
  background:var(--surface);
  border-radius:10px;
  padding:4px;
  margin-bottom:16px;
  border:1px solid var(--surface3);
}
.tab{
  flex:1;
  padding:8px 12px;
  text-align:center;
  font-size:.8rem;font-weight:600;
  color:var(--text2);
  border:none;background:none;
  border-radius:8px;
  cursor:pointer;
  transition:all .2s;
}
.tab.active{background:var(--accent);color:#fff}
.tab:hover:not(.active){color:var(--text)}

/* --- 区切り線 --- */
.divider{
  height:1px;
  background:var(--surface3);
  margin:16px 0;
}

/* --- ユーザーアバター --- */
.user-avatar{
  width:32px;height:32px;
  border-radius:50%;
  object-fit:cover;
  flex-shrink:0;
}
.user-avatar-emoji{
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  flex-shrink:0;
}
.nav-avatar-img{
  width:24px;height:24px;
  border-radius:50%;
  object-fit:cover;
  border:1px solid var(--surface3);
}

/* --- プロフィール編集フォーム --- */
.profile-edit-section{
  background:var(--surface);
  border:1px solid var(--surface3);
  border-radius:var(--radius);
  padding:24px;
  margin-bottom:16px;
  animation:fadeIn .4s ease;
}
.profile-edit-title{
  font-size:1rem;font-weight:700;
  margin-bottom:16px;
  display:flex;align-items:center;gap:8px;
}
.profile-setup-welcome{
  text-align:center;
  margin-bottom:20px;
  animation:fadeIn .5s ease;
}
.profile-setup-welcome .welcome-emoji{
  font-size:2.5rem;
  animation:float 3s ease-in-out infinite;
  margin-bottom:8px;
}
.profile-setup-welcome .welcome-title{
  font-size:1.15rem;font-weight:900;
  background:linear-gradient(135deg,var(--accent),var(--pink));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:6px;
}
.profile-setup-welcome .welcome-desc{
  font-size:.82rem;color:var(--text2);line-height:1.6;
}

/* アバターアップロードUI */
.avatar-upload-area{
  display:flex;align-items:center;gap:16px;
  margin-bottom:16px;
}
.avatar-preview{
  width:80px;height:80px;
  border-radius:50%;
  border:2px dashed var(--surface3);
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;
  overflow:hidden;
  flex-shrink:0;
  transition:border-color .2s;
  background:var(--surface2);
  cursor:pointer;
  position:relative;
}
.avatar-preview:hover{border-color:var(--accent)}
.avatar-preview img{
  width:100%;height:100%;
  object-fit:cover;
  border-radius:50%;
}
.avatar-preview .avatar-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  opacity:0;
  transition:opacity .2s;
  font-size:.7rem;
  color:#fff;
}
.avatar-preview:hover .avatar-overlay{opacity:1}
.avatar-upload-info{flex:1;min-width:0}
.avatar-upload-info .upload-label{
  font-size:.82rem;font-weight:600;margin-bottom:4px;
}
.avatar-upload-info .upload-hint{
  font-size:.7rem;color:var(--text2);line-height:1.5;
}
.avatar-upload-btn{
  display:inline-flex;align-items:center;gap:4px;
  padding:6px 14px;margin-top:6px;
  font-size:.75rem;font-weight:600;
  background:var(--surface2);
  border:1px solid var(--surface3);
  border-radius:20px;
  color:var(--text);
  cursor:pointer;
  transition:all .2s;
}
.avatar-upload-btn:hover{border-color:var(--accent);color:var(--accent2)}
.avatar-remove-btn{
  font-size:.7rem;color:var(--danger);
  border:none;background:none;
  cursor:pointer;margin-top:4px;
  padding:2px 0;
}
.avatar-remove-btn:hover{text-decoration:underline}

/* 文字数カウンター */
.char-count{
  font-size:.68rem;
  color:var(--text2);
  text-align:right;
  margin-top:2px;
}
.char-count.over{color:var(--danger)}

/* --- ユーティリティ --- */
.hidden{display:none!important}
.text-center{text-align:center}
.text-muted{color:var(--text2)}
.text-sm{font-size:.8rem}
.text-xs{font-size:.7rem}
.mt-8{margin-top:8px}
.mt-16{margin-top:16px}
.mt-24{margin-top:24px}
.mb-8{margin-bottom:8px}
.mb-16{margin-bottom:16px}

/* --- レスポンシブ（モバイル） --- */
@media(max-width:420px){
  .page{padding:14px}
  .card{padding:14px}
  .post-card{padding:12px}
  .board-card{padding:12px 14px}
}

/* ============================================================
   広告コンテナ共通スタイル
   ============================================================ */
[id$="-banner-ad"],
[id$="-ad"] {
  min-height: 0;
  transition: min-height .3s;
}
[id$="-banner-ad"]:not(:empty),
[id$="-ad"]:not(:empty) {
  min-height: 60px;
}
/* AdSense/プレースホルダー共通 */
.ad-placeholder {
  background: var(--surface2);
  border: 1px dashed var(--surface3);
  border-radius: 8px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .68rem;
  color: var(--text2);
  letter-spacing: .05em;
}

/* ============================================================
   デスクトップ サイドバーレイアウト
   モバイル（<768px）: 下部タブバーを維持（Capacitorアプリ最適）
   デスクトップ（≥768px）: 左サイドバー（Twitter/Claude型）
   ============================================================ */

/* サイドバー本体（デフォルト非表示） */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;
  width:240px;
  background:var(--surface);
  border-right:1px solid var(--surface3);
  flex-direction:column;
  overflow-y:auto;
  z-index:100;
  display:none;
}

/* デスクトップでサイドバーを表示・ナビバーを非表示 */
@media(min-width:768px){
  body.has-sidebar .sidebar{display:flex}
  body.has-sidebar .nav-bar{display:none!important}
  body.has-sidebar .page{
    padding-left:260px;
    padding-bottom:20px;
  }
  body.has-sidebar .toast{bottom:40px}
  body.has-sidebar .modal-overlay{left:240px}
}

/* ----- サイドバー内部スタイル ----- */

/* ロゴ */
.sidebar-logo{
  padding:24px 20px 16px;
  border-bottom:1px solid var(--surface3);
  flex-shrink:0;
}
.sb-logo-text{
  font-size:1.05rem;font-weight:900;
  background:linear-gradient(135deg,var(--accent),var(--accent2),#fd79a8);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.sb-logo-sub{font-size:.62rem;color:var(--text2);margin-top:2px;letter-spacing:.06em}

/* ユーザー情報 */
.sidebar-user{
  display:flex;align-items:center;gap:10px;
  padding:14px 18px;
  border-bottom:1px solid var(--surface3);
  cursor:pointer;transition:background .2s;
  flex-shrink:0;
}
.sidebar-user:hover{background:var(--surface2)}
.sb-avatar-wrap{flex-shrink:0}
.sb-user-info{flex:1;min-width:0;overflow:hidden}
.sb-nickname{
  font-size:.88rem;font-weight:700;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.sb-type{font-size:.68rem;color:var(--text2);margin-top:1px}

/* ナビリンク */
.sidebar-nav{
  flex:1;
  padding:8px 0;
  display:flex;flex-direction:column;
  overflow-y:auto;
}
.sb-item{
  display:flex;align-items:center;gap:12px;
  padding:11px 18px;
  color:var(--text2);text-decoration:none;
  font-size:.88rem;font-weight:500;
  transition:all .2s;
  position:relative;
  border:none;background:none;width:100%;cursor:pointer;
  border-left:3px solid transparent;
  text-align:left;
}
.sb-item:hover{background:var(--surface2);color:var(--text);border-left-color:rgba(108,92,231,.35)}
.sb-item.active{color:var(--accent2);font-weight:700;background:rgba(108,92,231,.07);border-left-color:var(--accent)}
.sb-icon{font-size:1.15rem;width:24px;text-align:center;flex-shrink:0}
.sb-label{flex:1}
.sb-badge{
  background:var(--danger);color:#fff;
  border-radius:50px;font-size:.62rem;font-weight:700;
  padding:1px 6px;min-width:18px;text-align:center;
  display:none;
}
.sb-badge.show{display:inline-block}

/* ALPHA SOON バッジ */
.sb-soon{
  font-size:.58rem;font-weight:800;letter-spacing:.05em;
  background:linear-gradient(135deg,#6c5ce7,#a29bfe);
  color:#fff;border-radius:50px;padding:2px 7px;
  flex-shrink:0;
}
.sb-item-locked{opacity:.65}
.sb-item-locked:hover{opacity:1}

/* モバイルナビ SOON バッジ */
.nav-item-soon{
  position:relative;
}
.nav-item-soon::after{
  content:'SOON';
  position:absolute;top:-6px;right:50%;transform:translateX(50%);
  font-size:.52rem;font-weight:800;letter-spacing:.04em;
  background:linear-gradient(135deg,#6c5ce7,#a29bfe);
  color:#fff;border-radius:50px;padding:1px 5px;
  white-space:nowrap;
}

/* ポイント表示 */
.sb-points-area{
  display:flex;align-items:center;gap:6px;
  padding:10px 18px;
  border-top:1px solid var(--surface3);
  font-size:.75rem;color:var(--text2);
  flex-shrink:0;
}
.sb-points-icon{font-size:1rem}
.sb-points-val{color:var(--warning);font-weight:700}
.sb-points-unit{font-size:.65rem}

/* フッター（ログアウト） */
.sidebar-footer{
  padding:12px 18px;
  border-top:1px solid var(--surface3);
  flex-shrink:0;
}
.sb-logout-btn{
  width:100%;
  padding:8px 16px;
  background:transparent;
  border:1px solid var(--surface3);
  border-radius:8px;
  color:var(--text2);font-size:.78rem;font-weight:500;
  cursor:pointer;transition:all .2s;
}
.sb-logout-btn:hover{border-color:var(--danger);color:var(--danger)}

/* サイドバー内法務リンク */
.sb-legal-links{
  display:flex;flex-wrap:wrap;gap:6px;
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid var(--surface3);
}
.sb-legal-link{
  font-size:.65rem;color:var(--text2);text-decoration:none;
  transition:color .2s;
}
.sb-legal-link:hover{color:var(--accent2)}
.sb-copyright{
  margin-top:8px;font-size:.62rem;color:var(--surface3);
}

/* ページ下部共通フッター（モバイルで表示、デスクトップはサイドバーで代替） */
.page-footer{
  background:var(--surface);
  border-top:1px solid var(--surface3);
  padding:24px 20px calc(24px + env(safe-area-inset-bottom,0px));
  margin-top:40px;
}
.page-footer-inner{
  max-width:640px;
  margin:0 auto;
  text-align:center;
}
.page-footer-links{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:4px 12px;
  margin-bottom:10px;
}
.page-footer-links a{font-size:.72rem;color:var(--text2);text-decoration:none;transition:color .2s}
.page-footer-links a:hover{color:var(--accent2)}
.pf-sep{color:var(--surface3);font-size:.7rem}
.page-footer-disclaimer{
  font-size:.65rem;color:var(--text2);line-height:1.6;
  margin-bottom:6px;
  opacity:.7;
}
.page-footer-copy{font-size:.62rem;color:var(--surface3)}
/* デスクトップではページフッターを非表示（サイドバーに移動） */
@media(min-width:768px){
  .page-footer{display:none}
}

/* ============================================================
   ダークモード
   ============================================================ */
:root[data-theme="dark"],
html[data-theme="dark"],
body[data-theme="dark"],
[data-theme="dark"]{
  --bg:#0a0a0f;
  --surface:#12121e;
  --surface2:#1a1a2e;
  --surface3:#242440;
  --accent:#6c5ce7;
  --accent2:#a29bfe;
  --pink:#e84393;
  --text:#e8e8ef;
  --text2:#7a7a9e;
  --success:#00b894;
  --warning:#fdcb6e;
  --danger:#e17055;
  --shadow:0 8px 32px rgba(0,0,0,.5);
  --fam-commanders:0,184,148;
  --fam-catalysts:253,203,110;
}
html[data-theme="dark"],
body[data-theme="dark"]{
  background:var(--bg);
  color:var(--text);
}
[data-theme="dark"] a{color:var(--accent2)}
[data-theme="dark"] a:hover{color:var(--accent)}
[data-theme="dark"] .sb-logo-text{
  background:linear-gradient(135deg,var(--accent),var(--accent2),#fd79a8);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
[data-theme="dark"] .modal-overlay{background:rgba(0,0,0,.75)}
[data-theme="dark"] .modal{box-shadow:0 24px 64px rgba(0,0,0,.7);border-color:rgba(255,255,255,.06)}
[data-theme="dark"] .form-input:focus{box-shadow:0 0 0 3px rgba(108,92,231,.22)}
[data-theme="dark"] .card:hover{box-shadow:0 4px 20px rgba(108,92,231,.12)}
[data-theme="dark"] .toast{background:var(--surface2);box-shadow:var(--shadow)}
[data-theme="dark"] .ad-placeholder{
  background:rgba(255,255,255,.03);
  border-color:rgba(255,255,255,.08);
  color:rgba(255,255,255,.15);
}

/* テーマトグルボタン（サイドバー内） */
.sb-theme-btn{
  display:flex;align-items:center;gap:8px;
  width:100%;
  padding:7px 14px;
  margin-top:8px;
  background:transparent;
  border:1px solid var(--surface3);
  border-radius:8px;
  color:var(--text2);font-size:.78rem;font-weight:500;
  cursor:pointer;transition:all .2s;
  text-align:left;
}
.sb-theme-btn:hover{border-color:var(--accent);color:var(--accent2)}

/* モバイル用テーマトグルボタン（右下固定） */
.theme-toggle-mobile{
  position:fixed;
  bottom:calc(68px + env(safe-area-inset-bottom,0px));
  right:12px;
  width:34px;height:34px;
  background:var(--surface2);
  border:1px solid var(--surface3);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.95rem;
  cursor:pointer;
  z-index:101;
  transition:all .2s;
  box-shadow:var(--shadow);
}
.theme-toggle-mobile:hover{border-color:var(--accent)}
@media(min-width:768px){.theme-toggle-mobile{display:none}}

/* モバイル用言語切替ボタン（テーマボタンの左隣） */
.lang-toggle-mobile{
  position:fixed;
  bottom:calc(68px + env(safe-area-inset-bottom,0px));
  right:52px;
  width:34px;height:34px;
  background:var(--surface2);
  border:1px solid var(--surface3);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;
  cursor:pointer;
  z-index:101;
  transition:all .2s;
  box-shadow:var(--shadow);
}
.lang-toggle-mobile:hover{border-color:var(--accent)}
@media(min-width:768px){.lang-toggle-mobile{display:none}}

/* ============================================================
   ダークモード: カラーコントラスト修正
   ============================================================ */

/* テストバナー */
[data-theme="dark"] .test-banner{
  background:rgba(253,203,110,.07);
  border-color:rgba(253,203,110,.25);
  color:#fdcb6e;
}

/* バッジ */
[data-theme="dark"] .badge{font-weight:700;opacity:1}

/* マッチングページタブ */
[data-theme="dark"] .mode-tab:not(.active){color:var(--text2)}
[data-theme="dark"] .dist-tab:not(.active){color:var(--text2);border-color:var(--surface3)}

/* スコアバーのラベル文字 */
[data-theme="dark"] .match-score-label{color:rgba(255,255,255,.8)}

/* ステータスバッジ */
[data-theme="dark"] .status-online{color:#00b894}
