/* ============================================
   GearCrew Design Tokens
   ============================================ */
:root {
  --color-background-primary: #FFFFFF;
  --color-background-secondary: #F7F2EE;
  --color-background-tertiary: #EFE7E0;
  --color-text-primary: #1F1714;
  --color-text-secondary: #6B5C54;
  --color-text-tertiary: #A99B91;
  --color-border-primary: #1F1714;
  --color-border-secondary: #6B5C54;
  --color-border-tertiary: #DCD2CA;
  --color-accent: #D85A30;
  --color-accent-dark: #B84A24;
  --color-accent-light: #FAECE7;
  --color-accent-text: #712B13;

  --color-success-bg: #E1F5EE;
  --color-success-fg: #085041;
  --color-warning-bg: #FAEEDA;
  --color-warning-fg: #633806;
  --color-info-bg: #E6F1FB;
  --color-info-fg: #0C447C;
  --color-purple-bg: #EEEDFE;
  --color-purple-fg: #3C3489;

  --border-radius-sm: 4px;
  --border-radius-md: 8px;
  --border-radius-lg: 12px;
  --border-radius-xl: 16px;

  --shadow-sm: 0 1px 2px rgba(31,23,20,0.04);
  --shadow-md: 0 4px 12px rgba(31,23,20,0.06);
  --shadow-lg: 0 8px 28px rgba(31,23,20,0.08);
}

* {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
  font-family: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--color-background-secondary);
  color: var(--color-text-primary);
  -webkit-font-smoothing: antialiased;
  font-size: 14px;
  line-height: 1.5;
}

a { color: var(--color-accent); text-decoration: none; }
a:hover { text-decoration: underline; }

input, select, textarea, button { font-family: inherit; }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ============================================
   ログイン画面
   ============================================ */
.auth-wrap {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: var(--color-background-primary);
}

.auth-left {
  background: linear-gradient(140deg, #FAECE7 0%, #F7E5C9 60%, #EFE7E0 100%);
  padding: 60px 70px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.auth-left::before {
  content: '';
  position: absolute;
  top: -120px; right: -120px;
  width: 380px; height: 380px;
  border-radius: 50%;
  background: rgba(216,90,48,0.10);
  filter: blur(20px);
}
.auth-left::after {
  content: '';
  position: absolute;
  bottom: -100px; left: -80px;
  width: 280px; height: 280px;
  border-radius: 50%;
  background: rgba(8,80,65,0.08);
  filter: blur(20px);
}

.auth-brand {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 60px; position: relative; z-index: 1;
}
.brand-mark {
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.brand-mark img { width: 100%; height: 100%; object-fit: contain; display: block; }
.brand-name { font-weight: 700; font-size: 20px; color: var(--color-text-primary); }

.auth-hero {
  font-size: 44px;
  font-weight: 700;
  line-height: 1.25;
  margin: 0 0 20px;
  position: relative;
  z-index: 1;
  letter-spacing: -0.01em;
}
.auth-hero .accent { color: var(--color-accent); }

.auth-lead {
  font-size: 14px;
  line-height: 1.8;
  color: var(--color-text-secondary);
  max-width: 460px;
  margin: 0 0 32px;
  position: relative;
  z-index: 1;
}

.auth-points {
  list-style: none;
  padding: 0; margin: 0 0 36px;
  position: relative; z-index: 1;
}
.auth-points li {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0;
  font-size: 13px;
  color: var(--color-text-primary);
}
.auth-points i { color: var(--color-accent); width: 20px; }

.auth-stats {
  display: flex; gap: 32px;
  padding-top: 24px;
  border-top: 1px solid rgba(31,23,20,0.10);
  position: relative; z-index: 1;
}
.auth-stats > div { display: flex; flex-direction: column; }
.auth-stats strong { font-size: 22px; font-weight: 700; color: var(--color-text-primary); }
.auth-stats span { font-size: 11px; color: var(--color-text-secondary); }

.auth-right {
  padding: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.auth-card {
  width: 100%;
  max-width: 400px;
}
.auth-tabs {
  display: flex;
  border-bottom: 1px solid var(--color-border-tertiary);
  margin-bottom: 28px;
}
.auth-tab {
  flex: 1; text-align: center;
  padding: 12px 0;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-tertiary);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.auth-tab.active {
  color: var(--color-accent);
  border-bottom-color: var(--color-accent);
}
.auth-tab:hover { text-decoration: none; color: var(--color-text-primary); }

.auth-title {
  font-size: 26px;
  font-weight: 700;
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}
.auth-sub {
  color: var(--color-text-secondary);
  font-size: 13px;
  margin: 0 0 24px;
}

.sso-group { display: flex; flex-direction: column; gap: 8px; }
.sso-btn {
  width: 100%;
  display: flex; align-items: center; justify-content: center;
  gap: 10px;
  padding: 11px 14px;
  border-radius: var(--border-radius-md);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid var(--color-border-tertiary);
  background: var(--color-background-primary);
  color: var(--color-text-primary);
  transition: all .15s ease;
}
.sso-btn:hover { box-shadow: var(--shadow-sm); transform: translateY(-1px); }
.sso-google {}
.sso-line {
  background: #06C755; color: white; border-color: #06C755;
}
.sso-line:hover { background: #05B14C; }
.sso-icon { display: flex; align-items: center; }

.auth-divider {
  display: flex; align-items: center; gap: 12px;
  margin: 22px 0;
  font-size: 11px;
  color: var(--color-text-tertiary);
}
.auth-divider::before, .auth-divider::after {
  content: ''; flex: 1; height: 1px;
  background: var(--color-border-tertiary);
}

.auth-form { display: flex; flex-direction: column; gap: 14px; }
.form-row { display: flex; flex-direction: column; gap: 6px; }
.form-row label { font-size: 12px; font-weight: 500; color: var(--color-text-primary); }
.form-row input {
  padding: 10px 12px;
  border-radius: var(--border-radius-md);
  border: 1px solid var(--color-border-tertiary);
  background: var(--color-background-primary);
  font-size: 14px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.form-row input:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(216,90,48,0.12);
}

/* パスワード入力＋表示切替トグル */
.password-field { position: relative; display: flex; }
.password-field input { flex: 1; padding-right: 44px; width: 100%; }
.password-toggle {
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  color: var(--color-text-tertiary);
  cursor: pointer;
  font-size: 15px;
  padding: 0;
  transition: color .15s;
}
.password-toggle:hover { color: var(--color-accent); }

.form-aux {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12px; flex-wrap: wrap; gap: 6px;
}
.checkbox-inline {
  display: flex; align-items: center; gap: 6px;
  color: var(--color-text-secondary);
  cursor: pointer;
}
.checkbox-inline input { accent-color: var(--color-accent); }
.link-muted { color: var(--color-text-secondary); text-decoration: none; }
.link-muted:hover { color: var(--color-accent); text-decoration: underline; }

.auth-submit {
  margin-top: 4px;
  padding: 12px;
  border: none;
  background: var(--color-accent);
  color: white;
  font-weight: 600;
  font-size: 14px;
  border-radius: var(--border-radius-md);
  cursor: pointer;
  transition: background .15s, transform .05s;
}
.auth-submit:hover { background: var(--color-accent-dark); }
.auth-submit:active { transform: scale(0.99); }

.auth-error {
  padding: 10px 12px;
  background: var(--color-accent-light);
  color: var(--color-accent-text);
  border-radius: var(--border-radius-md);
  font-size: 12px;
}

.auth-foot {
  margin-top: 20px; text-align: center;
  font-size: 13px; color: var(--color-text-secondary);
}

/* ============================================
   メインアプリ
   ============================================ */
.app-shell {
  width: 100%;
  min-height: 100vh;
}

.app-frame {
  background: var(--color-background-primary);
  min-height: 100vh;
}
#web-screen { display: block; }

/* ヘッダー（全幅・上部固定） */
.w-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  padding: 0 28px;
  height: 60px;
  border-bottom: 1px solid var(--color-border-tertiary);
  background: var(--color-background-primary);
  position: sticky; top: 0; z-index: 50;
  box-shadow: var(--shadow-sm);
}
.w-logo {
  display: flex; align-items: center; gap: 9px;
  font-weight: 700; font-size: 16px;
  flex-shrink: 0;
}
.w-logo-mark {
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.w-logo-mark img {
  width: 100%; height: 100%; object-fit: contain; display: block;
}
.w-header-center {
  display: flex; align-items: center; gap: 16px;
  flex: 1; justify-content: center; max-width: 720px; margin: 0 auto;
}
.w-header-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

.w-nav { display: flex; gap: 4px; font-size: 13px; flex-shrink: 0; }
.w-nav-item {
  padding: 6px 12px; border-radius: var(--border-radius-md);
  color: var(--color-text-secondary); cursor: pointer;
  transition: all .12s;
}
.w-nav-item.active {
  background: var(--color-accent-light);
  color: var(--color-accent-text); font-weight: 600;
}
.w-nav-item:hover { background: var(--color-background-secondary); }

.w-search {
  flex: 1; min-width: 200px; max-width: 420px; padding: 8px 14px;
  border: 1px solid var(--color-border-tertiary);
  border-radius: 999px;
  font-size: 13px;
  background: var(--color-background-secondary);
  outline: none;
  transition: all .12s;
}
.w-search:focus { border-color: var(--color-accent); background: var(--color-background-primary); }
/* textareaは複数行入力。pill型(999px)だと縦に伸ばした際に丸い角がテキストを隠すため、
   控えめな角丸＋上下余白でテキスト先頭が切れないようにする */
textarea.w-search {
  border-radius: 18px;
  padding: 12px 16px;
  line-height: 1.6;
  max-width: 100%;
}

.w-userbox {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 10px 4px 4px; border-radius: 999px; cursor: pointer;
  transition: background .12s;
}
.w-userbox:hover { background: var(--color-background-secondary); }
.w-userbox-name { font-size: 12px; color: var(--color-text-secondary); font-weight: 500; }
.w-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--color-accent-light); color: var(--color-accent-text);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 600; flex-shrink: 0;
}
.w-logout {
  width: 34px; height: 34px; border-radius: 50%;
  border: 1px solid var(--color-border-tertiary);
  background: var(--color-background-primary);
  color: var(--color-text-secondary); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; transition: all .12s;
}
.w-logout:hover { background: var(--color-accent-light); color: var(--color-accent-text); border-color: var(--color-accent-light); }

/* グリッド（全幅・全高） */
.w-grid-3 {
  display: grid;
  grid-template-columns: 232px minmax(0, 1fr) 300px;
  min-height: calc(100vh - 60px);
}
.w-grid-2 {
  display: grid;
  grid-template-columns: 232px minmax(0, 1fr);
  min-height: calc(100vh - 60px);
}
.w-side {
  background: var(--color-background-secondary);
  padding: 18px 12px;
  border-right: 1px solid var(--color-border-tertiary);
  position: sticky; top: 60px; align-self: start;
  height: calc(100vh - 60px); overflow-y: auto;
}
.w-side-section {
  font-size: 10px; color: var(--color-text-tertiary);
  text-transform: uppercase; letter-spacing: 0.05em;
  padding: 14px 8px 4px;
}
.w-side-section:first-child { padding-top: 2px; }
.w-side-item {
  padding: 8px 12px; font-size: 13px; margin-bottom: 1px;
  border-radius: var(--border-radius-md);
  cursor: pointer; color: var(--color-text-secondary);
  display: flex; align-items: center; justify-content: space-between;
  transition: background .1s;
}
.w-side-item.active {
  background: var(--color-background-primary);
  color: var(--color-accent); font-weight: 600;
  box-shadow: var(--shadow-sm);
}
.w-side-item:hover { background: var(--color-background-primary); }
.w-side-badge {
  background: var(--color-accent); color: white;
  font-size: 9px; padding: 1px 6px; border-radius: 999px;
  font-weight: 600;
}
.w-main {
  padding: 28px 36px; overflow-y: auto;
  max-width: 1080px; width: 100%; margin: 0 auto;
}
.w-rail {
  background: var(--color-background-secondary);
  padding: 20px 16px;
  border-left: 1px solid var(--color-border-tertiary);
  position: sticky; top: 60px; align-self: start;
  height: calc(100vh - 60px); overflow-y: auto;
}
.w-h1 { font-size: 22px; font-weight: 700; margin: 0 0 4px; }
.w-sub { font-size: 13px; color: var(--color-text-secondary); margin: 0 0 20px; }
.w-h2 { font-size: 15px; font-weight: 600; margin: 22px 0 10px; }

.w-stat-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 10px; margin-bottom: 16px;
}
.w-stat {
  background: var(--color-background-secondary);
  padding: 10px 12px; border-radius: var(--border-radius-md);
}
.w-stat-label { font-size: 11px; color: var(--color-text-secondary); }
.w-stat-value { font-size: 18px; font-weight: 600; margin-top: 2px; }
.w-stat-trend { font-size: 10px; margin-top: 1px; }

.w-card {
  background: var(--color-background-primary);
  border: 1px solid var(--color-border-tertiary);
  border-radius: var(--border-radius-lg);
  padding: 12px 14px; margin-bottom: 10px;
  transition: box-shadow .12s;
}
.w-card:hover { box-shadow: var(--shadow-sm); }

.w-pill {
  display: inline-block; font-size: 10px;
  padding: 2px 8px; border-radius: 999px;
  background: var(--color-background-secondary);
  color: var(--color-text-secondary);
  margin-right: 4px;
  font-weight: 500;
}
.w-pill-coral { background: var(--color-accent-light); color: var(--color-accent-text); }
.w-pill-teal { background: var(--color-success-bg); color: var(--color-success-fg); }
.w-pill-blue { background: var(--color-info-bg); color: var(--color-info-fg); }
.w-pill-amber { background: var(--color-warning-bg); color: var(--color-warning-fg); }
.w-pill-purple { background: var(--color-purple-bg); color: var(--color-purple-fg); }

.w-btn-primary {
  background: var(--color-accent); color: white; border: none;
  padding: 7px 14px; border-radius: var(--border-radius-md);
  font-size: 12px; font-weight: 600; cursor: pointer;
  transition: background .12s;
}
.w-btn-primary:hover { background: var(--color-accent-dark); }

.w-btn-outline {
  background: transparent;
  border: 1px solid var(--color-border-tertiary);
  padding: 6px 12px; border-radius: var(--border-radius-md);
  font-size: 12px; cursor: pointer;
  color: var(--color-text-primary);
  transition: background .12s;
}
.w-btn-outline:hover { background: var(--color-background-secondary); }

.w-row { display: flex; justify-content: space-between; align-items: center; }

.w-search-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
}
.w-result-card {
  background: var(--color-background-primary);
  border: 1px solid var(--color-border-tertiary);
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  cursor: pointer;
  transition: transform .12s, box-shadow .12s;
}
.w-result-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.w-result-img {
  aspect-ratio: 4/3;
  background: var(--color-background-secondary);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: var(--color-text-tertiary);
}

/* ===== ダッシュボード新着機材：グリッド／リスト表示 ===== */
.dash-view-toggle .dash-view-btn {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--color-border-tertiary);
  background: var(--color-background-primary);
  color: var(--color-text-tertiary);
  border-radius: 8px; cursor: pointer; font-size: 13px;
  transition: all .12s;
}
.dash-view-toggle .dash-view-btn:hover { color: var(--color-text-secondary); }
.dash-view-toggle .dash-view-btn.active {
  background: var(--color-accent); color: #fff; border-color: var(--color-accent);
}
/* グリッド：1画面に複数枚見える小型カード（自動列数） */
.dash-grid-wrap {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 12px;
}
.dash-grid-img { aspect-ratio: 16/10; }
/* リスト：横並びコンパクト行 */
.dash-list-wrap { display: flex; flex-direction: column; gap: 8px; }
.dash-list-row {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 12px;
  background: var(--color-background-primary);
  border: 1px solid var(--color-border-tertiary);
  border-radius: 10px; cursor: pointer;
  transition: background .12s, box-shadow .12s;
}
.dash-list-row:hover { box-shadow: var(--shadow-sm); background: var(--color-background-secondary); }
.dash-list-thumb {
  flex: 0 0 auto; width: 56px; height: 56px;
  border-radius: 8px; overflow: hidden;
  background: var(--color-background-secondary);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-text-tertiary); font-size: 16px;
}

.w-filter-section {
  padding: 10px 4px;
  border-bottom: 1px solid var(--color-border-tertiary);
}
.w-filter-title {
  font-size: 11px; font-weight: 600;
  margin-bottom: 8px;
}
.w-checkbox {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; padding: 3px 0;
  color: var(--color-text-secondary);
  cursor: pointer;
}
.w-checkbox input { accent-color: var(--color-accent); }
/* 詳細検索トグルボタン */
.w-filter-detail-btn {
  display: flex; align-items: center; gap: 6px;
  width: 100%; margin-top: 10px; padding: 8px 10px;
  background: var(--color-bg-tertiary, #f5f3ef); border: 1px solid var(--color-border-tertiary, #e5e1d8);
  border-radius: 10px; font-size: 12px; font-weight: 600;
  color: var(--color-text-secondary, #666); cursor: pointer; transition: all .15s;
}
.w-filter-detail-btn:hover { border-color: var(--color-accent, #e2583e); color: var(--color-accent, #e2583e); }
.w-filter-detail-btn .fa-chevron-down, .w-filter-detail-btn .fa-chevron-up { margin-left: auto; font-size: 10px; }

.w-cal-grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.w-cal-cell {
  aspect-ratio: 4/3;
  border-radius: var(--border-radius-md);
  padding: 6px; font-size: 11px;
  border: 1px solid var(--color-border-tertiary);
  background: var(--color-background-primary);
}
.w-cal-free { background: var(--color-success-bg); border-color: #9FE1CB; color: #04342C; }
.w-cal-busy { background: var(--color-accent-light); border-color: #F5C4B3; color: #4A1B0C; }
.w-cal-tent { background: var(--color-warning-bg); border-color: #FAC775; color: #412402; }

/* ===== メッセージ画面レイアウト（LINE風：画面の高さいっぱい・入力欄を最下部固定） ===== */
.msg-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  /* ヘッダー(60px)を除いた画面の高さいっぱい */
  height: calc(100vh - 60px);
  min-height: 480px;
  overflow: hidden;
}
.msg-chat-pane {
  display: flex;
  flex-direction: column;
  min-height: 0;        /* flex子のはみ出し防止（スクロールを効かせる） */
  overflow: hidden;
}
/* 相手情報ヘッダー（固定） */
.msg-chat-header {
  flex-shrink: 0;
  padding: 12px 16px;
  border-bottom: 1px solid var(--color-border-tertiary);
}
/* メッセージ一覧（残りの高さをすべて使ってスクロール） */
.msg-chat-window {
  flex: 1 1 auto;
  min-height: 0;
  padding: 14px 16px;
  overflow-y: auto;
}
/* 入力欄（最下部固定） */
.msg-chat-input {
  flex-shrink: 0;
  padding: 10px 16px;
  border-top: 1px solid var(--color-border-tertiary);
}
/* メッセージ入力フィールドは .w-search の max-width:420px 制限を解除して
   送信ボタン以外の残り幅をすべて使う（入力幅を広く） */
.msg-input-field { flex: 1 1 auto; max-width: 100%; min-width: 0; }

.w-msg-list {
  border-right: 1px solid var(--color-border-tertiary);
  overflow-y: auto;
  min-height: 0;
}
.w-msg-item {
  padding: 10px 12px;
  border-bottom: 1px solid var(--color-border-tertiary);
  cursor: pointer;
}
.w-msg-item.active { background: var(--color-background-secondary); }
.w-msg-item:hover { background: var(--color-background-secondary); }

/* メッセージ1件の行（吹き出し＋メタ情報をまとめる） */
.msg-row { display: flex; flex-direction: column; margin-bottom: 10px; max-width: 100%; }
.msg-row.me { align-items: flex-end; }
.msg-row.them { align-items: flex-start; }

.msg-them {
  background: var(--color-background-secondary);
  padding: 8px 12px; border-radius: 14px 14px 14px 2px;
  width: fit-content; max-width: 100%;     /* wrap内で伸縮（実際の上限はwrapのmax-width） */
  font-size: 12px; line-height: 1.5;
  white-space: pre-wrap;                   /* 改行はそのまま・行内は自然に折り返す */
  overflow-wrap: break-word; word-break: normal;
}
.msg-me {
  background: var(--color-accent); color: white;
  padding: 8px 12px; border-radius: 14px 14px 2px 14px;
  width: fit-content; max-width: 100%;     /* wrap内で伸縮（実際の上限はwrapのmax-width） */
  font-size: 12px; line-height: 1.5;
  white-space: pre-wrap;                   /* 改行はそのまま・行内は自然に折り返す */
  overflow-wrap: break-word; word-break: normal;
}
/* 送信日時・既読の表示 */
.msg-meta {
  font-size: 9px; color: var(--color-text-tertiary);
  margin-top: 2px; display: flex; gap: 6px; align-items: center;
}
.msg-meta .msg-read { color: var(--color-accent); font-weight: 600; }
.msg-meta .msg-edited { color: var(--color-text-tertiary); font-style: italic; }

/* 取り消し（論理削除）されたメッセージのプレースホルダ */
.msg-deleted {
  background: transparent !important; color: var(--color-text-tertiary) !important;
  border: 1px dashed var(--color-border-tertiary);
  padding: 8px 12px; border-radius: 14px;
  max-width: 85%; width: fit-content;
  font-size: 12px; font-style: italic; line-height: 1.5;
  white-space: normal; overflow-wrap: break-word; word-break: normal;
}

/* グループ：システムメッセージ（入退室など）の中央表示 */
.msg-system { text-align: center; margin: 10px 0; }
.msg-system span {
  display: inline-block; background: var(--color-border-tertiary);
  color: var(--color-text-secondary); font-size: 11px;
  padding: 4px 12px; border-radius: 12px; line-height: 1.4;
}

/* グループ：相手の発言上に表示する送信者名 */
.msg-sender-name {
  font-size: 11px; color: var(--color-text-secondary);
  margin: 0 0 2px 2px; font-weight: 600;
}

/* グループ作成・メンバー追加の選択肢行 */
.gc-member-opt {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 8px; cursor: pointer;
}
.gc-member-opt:hover { background: var(--color-border-tertiary); }
.gc-member-opt input[type=checkbox] { width: 16px; height: 16px; cursor: pointer; }

/* 吹き出し＋操作メニューの横並びラッパ（LINE風に横幅を広く＝最大85%） */
.msg-bubble-wrap { display: flex; align-items: center; gap: 4px; max-width: 85%; min-width: 0; }
.msg-row.me .msg-bubble-wrap { flex-direction: row; }   /* メニューを吹き出しの左に */
.msg-row.them .msg-bubble-wrap { flex-direction: row; }

/* 操作メニュー（⋯ボタン＋ポップアップ） */
.msg-menu { position: relative; flex-shrink: 0; }
.msg-menu-btn {
  border: none; background: transparent; cursor: pointer;
  color: var(--color-text-tertiary); font-size: 16px; line-height: 1;
  padding: 2px 6px; border-radius: 6px; opacity: 0;
  transition: opacity .15s, background .15s;
}
.msg-row:hover .msg-menu-btn { opacity: .7; }
.msg-menu-btn:hover { opacity: 1; background: var(--color-background-secondary); }
.msg-menu-pop {
  display: none; position: absolute; top: 100%; right: 0; z-index: 30;
  background: var(--color-background-primary, #fff);
  border: 1px solid var(--color-border-tertiary);
  border-radius: 8px; box-shadow: 0 4px 16px rgba(0,0,0,.12);
  min-width: 130px; padding: 4px; margin-top: 2px;
}
.msg-menu-pop.open { display: block; }
.msg-menu-pop button {
  display: block; width: 100%; text-align: left;
  border: none; background: transparent; cursor: pointer;
  font-size: 12px; padding: 7px 10px; border-radius: 6px;
  color: var(--color-text-primary);
}
.msg-menu-pop button:hover { background: var(--color-background-secondary); }
.msg-menu-pop button.danger { color: var(--color-danger-fg, #d33); }

/* ===== 添付ファイル ===== */
/* 本文吹き出し＋添付を縦に積むスタック */
.msg-bubble-stack { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.msg-row.me .msg-bubble-stack { align-items: flex-end; }
.msg-row.them .msg-bubble-stack { align-items: flex-start; }

/* 画像サムネ */
.msg-attach-img-link { display: inline-block; line-height: 0; }
.msg-attach-img {
  max-width: 220px; max-height: 220px; width: auto; height: auto;
  border-radius: 12px; cursor: pointer; object-fit: cover;
  border: 1px solid var(--color-border-tertiary);
}
/* ファイルカード（画像以外） */
.msg-attach {
  display: flex; align-items: center; gap: 8px;
  background: var(--color-background-secondary);
  border: 1px solid var(--color-border-tertiary);
  border-radius: 12px; padding: 10px 12px;
  font-size: 12px; color: var(--color-text-primary);
  text-decoration: none; max-width: 260px; min-width: 180px;
}
.msg-attach:hover { background: var(--color-background-tertiary, #eee); }
.msg-attach i.fa-file { font-size: 18px; color: var(--color-accent); }
.msg-attach-name { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.msg-attach-size { color: var(--color-text-tertiary); font-size: 10px; flex-shrink: 0; }
.msg-attach-expired {
  background: transparent; border: 1px dashed var(--color-border-tertiary);
  color: var(--color-text-tertiary); font-style: italic; font-size: 11px;
  display: flex; align-items: center; gap: 6px; min-width: 0;
}

/* 添付ボタン（クリップ） */
.msg-attach-btn {
  border: none; background: transparent; cursor: pointer;
  color: var(--color-text-secondary); font-size: 16px;
  padding: 6px 8px; border-radius: 8px; flex-shrink: 0;
  transition: background .15s, color .15s;
}
.msg-attach-btn:hover { background: var(--color-background-secondary); color: var(--color-accent); }

/* ===== リアクション（既読代わりのスタンプ） ===== */
.msg-reacts { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 3px; align-items: center; }
.msg-row.me .msg-reacts { justify-content: flex-end; }
.msg-row.them .msg-reacts { justify-content: flex-start; }
.msg-react-chip {
  border: 1px solid var(--color-border-tertiary);
  background: var(--color-background-secondary);
  border-radius: 12px; padding: 1px 8px; font-size: 11px;
  cursor: pointer; line-height: 1.6; color: var(--color-text-secondary);
  transition: background .15s, border-color .15s;
}
.msg-react-chip:hover { background: var(--color-background-tertiary, #eee); }
.msg-react-chip.mine {
  background: var(--color-accent-bg, rgba(220,90,50,.12));
  border-color: var(--color-accent); color: var(--color-accent); font-weight: 600;
}
/* リアクション追加ボタン（顔アイコン） */
.msg-react-add {
  border: none; background: transparent; cursor: pointer;
  color: var(--color-text-tertiary); font-size: 12px;
  padding: 1px 5px; border-radius: 10px; opacity: 0;
  transition: opacity .15s, background .15s;
}
.msg-row:hover .msg-react-add { opacity: .6; }
.msg-react-add:hover { opacity: 1; background: var(--color-background-secondary); }
/* リアクション選択パレット（浮動） */
.msg-react-pop {
  z-index: 50; display: flex; gap: 2px;
  background: var(--color-background-primary, #fff);
  border: 1px solid var(--color-border-tertiary);
  border-radius: 22px; padding: 4px 6px;
  box-shadow: 0 6px 24px rgba(0,0,0,.18);
}
.msg-react-pop button {
  border: none; background: transparent; cursor: pointer;
  font-size: 20px; line-height: 1; padding: 4px 6px; border-radius: 50%;
  transition: transform .1s, background .15s;
}
.msg-react-pop button:hover { transform: scale(1.25); background: var(--color-background-secondary); }

.w-table { width: 100%; font-size: 12px; border-collapse: collapse; }
.w-table th {
  text-align: left; font-weight: 600;
  padding: 8px 10px; font-size: 11px;
  color: var(--color-text-secondary);
  border-bottom: 1px solid var(--color-border-tertiary);
}
.w-table td {
  padding: 10px; border-bottom: 1px solid var(--color-border-tertiary);
}
.w-table tr:hover td { background: var(--color-background-secondary); }

/* ============================================
   レスポンシブ
   ============================================ */
@media (max-width: 1100px) {
  .auth-wrap { grid-template-columns: 1fr; }
  .auth-left { padding: 40px 30px; }
  .auth-right { padding: 30px; }
  .auth-hero { font-size: 32px; }
  /* 右レールはたたむ */
  .w-grid-3 { grid-template-columns: 200px minmax(0, 1fr); }
  .w-grid-2 { grid-template-columns: 200px minmax(0, 1fr); }
  .w-rail { display: none; }
  .w-main { padding: 24px 28px; }
  .w-search-grid { grid-template-columns: repeat(2, 1fr); }
  .w-stat-grid { grid-template-columns: repeat(2, 1fr); }
  .w-header-center { display: none; }
}

@media (max-width: 720px) {
  /* メッセージ画面：スレッド一覧を上、チャットを下に縦積み（LINEアプリ風） */
  .msg-layout {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    height: calc(100vh - 60px);
  }
  .w-msg-list {
    max-height: 30vh;
    border-right: none;
    border-bottom: 1px solid var(--color-border-tertiary);
  }
  .msg-attach-img { max-width: 70vw; }

  /* サイドバーを上部の横スクロールバーに変換 */
  .w-grid-3, .w-grid-2 { grid-template-columns: 1fr; min-height: 0; }
  .w-side {
    position: sticky; top: 60px; height: auto;
    display: flex; flex-direction: row; align-items: center;
    gap: 4px; overflow-x: auto; overflow-y: hidden;
    padding: 8px 12px; border-right: none;
    border-bottom: 1px solid var(--color-border-tertiary);
    z-index: 40;
  }
  .w-side-section { display: none; }
  .w-side-item {
    flex-shrink: 0; white-space: nowrap;
    border: 1px solid var(--color-border-tertiary);
  }
  .w-side-item.active { border-color: var(--color-accent); }
  .w-main { padding: 18px 16px; }
}

@media (max-width: 600px) {
  .auth-hero { font-size: 26px; }
  .auth-left { padding: 30px 20px; }
  .auth-right { padding: 20px; }
  .w-search-grid { grid-template-columns: 1fr; }
  .w-stat-grid { grid-template-columns: repeat(2, 1fr); }
  .w-header { padding: 0 14px; }
  .w-userbox-name { display: none; }
  .w-logo span { display: none; }
}

/* ===== 法的ページ ===== */
.legal-wrap { max-width: 880px; margin: 0 auto; padding: 0 20px 60px; color: var(--color-text-primary, #1a1a2e); }
.legal-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; padding: 20px 0; border-bottom: 1px solid #eaeaf0; margin-bottom: 24px; }
.legal-brand { display: flex; align-items: center; gap: 8px; text-decoration: none; color: inherit; font-weight: 700; }
.legal-brand .brand-mark { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; }
.legal-nav { display: flex; gap: 16px; flex-wrap: wrap; font-size: 13px; }
.legal-nav a { color: #555; text-decoration: none; }
.legal-nav a.active { color: #6366f1; font-weight: 700; }
.legal-nav a.legal-back { color: #6366f1; }
.legal-notice { background: #fff7ed; border: 1px solid #fed7aa; border-radius: 8px; padding: 12px 16px; font-size: 13px; color: #9a3412; margin-bottom: 28px; }
.legal-notice i { margin-right: 6px; }
.legal-article h1 { font-size: 24px; margin-bottom: 6px; }
.legal-article h2 { font-size: 16px; margin: 26px 0 8px; padding-top: 10px; border-top: 1px solid #f0f0f5; }
.legal-article p { line-height: 1.9; font-size: 14px; color: #333; margin: 4px 0; }
.legal-article ol, .legal-article ul { margin: 6px 0 6px 1.4em; padding: 0; }
.legal-article ol > li, .legal-article ul > li { line-height: 1.9; font-size: 14px; color: #333; margin: 2px 0; }
.legal-article ol { list-style: decimal; }
.legal-article ul { list-style: disc; }
.legal-article li ul { margin-top: 4px; margin-bottom: 4px; }
.legal-article strong { font-weight: 700; color: #1a1a2e; }
.legal-note { background: #f8f8fc; border-left: 3px solid #c7c7d8; border-radius: 6px; padding: 10px 16px; margin: 14px 0; }
.legal-note p { font-size: 13px; color: #555; line-height: 1.8; margin: 6px 0; }
.legal-updated { color: #999; font-size: 12px; margin-top: 28px; margin-bottom: 16px; }
.legal-table { width: 100%; border-collapse: collapse; margin-top: 12px; font-size: 14px; }
.legal-table th, .legal-table td { border: 1px solid #eaeaf0; padding: 10px 12px; text-align: left; vertical-align: top; }
.legal-table th { background: #f8f8fc; width: 30%; font-weight: 600; }
.legal-footer { margin-top: 48px; padding-top: 20px; border-top: 1px solid #eaeaf0; text-align: center; font-size: 12px; color: #999; }
.legal-footer a { color: #6366f1; text-decoration: none; }

/* ===== トースト通知 ===== */
.gc-toast-box {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 10px;
  pointer-events: none;
}
.gc-toast {
  min-width: 220px;
  max-width: 360px;
  padding: 13px 18px;
  border-radius: 12px;
  background: #1a1a2e;
  color: #fff;
  font-size: 13.5px;
  font-weight: 600;
  line-height: 1.5;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.22);
  display: flex;
  align-items: center;
  gap: 10px;
  pointer-events: auto;
  animation: gcToastIn 0.28s cubic-bezier(0.18, 0.89, 0.32, 1.28);
}
.gc-toast i { font-size: 15px; }
.gc-toast-info { background: linear-gradient(135deg, #6366f1, #8b5cf6); }
.gc-toast-success { background: linear-gradient(135deg, #10b981, #059669); }
.gc-toast-error { background: linear-gradient(135deg, #ef4444, #dc2626); }
.gc-toast-out { animation: gcToastOut 0.3s ease forwards; }
@keyframes gcToastIn {
  from { opacity: 0; transform: translateX(24px) translateY(8px); }
  to { opacity: 1; transform: translateX(0) translateY(0); }
}
@keyframes gcToastOut {
  from { opacity: 1; transform: translateX(0); }
  to { opacity: 0; transform: translateX(24px); }
}

/* ===== モーダル ===== */
.gc-modal-back {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(15, 15, 35, 0.55);
  backdrop-filter: blur(3px);
  display: flex;
  align-items: center;
  justify-content: center;
  /* スクロールバー出現時でもモーダルが横にずれないよう中央軸を安定させる */
  scrollbar-gutter: stable both-edges;
  padding: 24px;
  animation: gcBackIn 0.2s ease;
}
.gc-modal {
  width: 100%;
  /* 左右余白を均等にしつつ入力しやすいよう幅を拡大 */
  max-width: 520px;
  margin: 0 auto;
  max-height: 90vh;
  overflow-y: auto;
  background: #fff;
  border-radius: 18px;
  padding: 30px 32px 26px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.3);
  animation: gcModalIn 0.26s cubic-bezier(0.18, 0.89, 0.32, 1.28);
}
.gc-modal h3 {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 4px;
  color: #1a1a2e;
}
.gc-modal .gc-modal-sub {
  font-size: 13px;
  color: #777;
  margin: 0 0 16px;
}
.gc-modal .gc-modal-actions {
  display: flex;
  gap: 10px;
  margin-top: 18px;
}
.gc-modal .gc-modal-actions .w-btn-primary,
.gc-modal .gc-modal-actions .w-btn-outline {
  flex: 1;
  justify-content: center;
}
/* モーダル内の入力欄は .w-search の max-width:420px 制限を解除して
   フォーム幅いっぱいに広げる（右側に余白が出て左右非対称に見えるのを防ぐ） */
.gc-modal .w-search { max-width: 100%; min-width: 0; }

/* 案件投稿モーダル：左右パディングを完全に対称にし、幅も少し広げて窮屈さを解消。
   フォーム要素はすべて width:100% なので、外枠パディングを左右均等にすることで
   白枠の中身が左右対称に収まる。 */
.gc-modal-job {
  max-width: 480px;
  padding-left: 26px;
  padding-right: 26px;
}
.gc-modal-job * { box-sizing: border-box; }
@keyframes gcBackIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes gcModalIn {
  from { opacity: 0; transform: translateY(16px) scale(0.97); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ============================================================
   運営者専用 管理画面
   ============================================================ */
.adm-shell { display: flex; min-height: 100vh; background: #f4f5fa; font-family: 'Noto Sans JP', sans-serif; color: #1a1a2e; }

/* サイドバー */
.adm-sidebar { width: 240px; background: #15162b; color: #cdd0e0; display: flex; flex-direction: column; position: fixed; top: 0; bottom: 0; left: 0; }
.adm-brand { display: flex; align-items: center; gap: 10px; padding: 20px 18px; border-bottom: 1px solid #26284a; }
.adm-brand-mark { width: 36px; height: 36px; display:flex; align-items:center; justify-content:center; }
.adm-brand-mark img { width: 100%; height: 100%; object-fit: contain; display: block; }
.adm-brand-name { font-weight: 700; color: #fff; font-size: 15px; }
.adm-brand-sub { font-size: 11px; color: #8a8db0; }
.adm-nav { flex: 1; padding: 12px 10px; display: flex; flex-direction: column; gap: 2px; overflow-y: auto; }
.adm-nav-item { display: flex; align-items: center; gap: 11px; width: 100%; text-align: left; background: none; border: none; color: #b6b9d4; padding: 11px 14px; border-radius: 9px; font-size: 13.5px; cursor: pointer; font-family: inherit; transition: background .15s, color .15s; }
.adm-nav-item i { width: 18px; text-align: center; font-size: 14px; }
.adm-nav-item:hover { background: #20223f; color: #fff; }
.adm-nav-item.active { background: linear-gradient(135deg,#6366f1,#8b5cf6); color: #fff; font-weight: 600; }
.adm-sidebar-foot { padding: 12px 10px 16px; border-top: 1px solid #26284a; display:flex; flex-direction: column; gap: 2px; }
.adm-foot-link { display:flex; align-items:center; gap:10px; background:none; border:none; color:#8a8db0; padding: 9px 14px; border-radius: 8px; font-size: 12.5px; cursor:pointer; text-decoration:none; font-family:inherit; }
.adm-foot-link:hover { background:#20223f; color:#fff; }

/* メイン */
.adm-main { flex: 1; margin-left: 240px; display: flex; flex-direction: column; }
.adm-topbar { height: 60px; background: #fff; border-bottom: 1px solid #e8e9f2; display: flex; align-items: center; justify-content: space-between; padding: 0 28px; position: sticky; top: 0; z-index: 10; }
.adm-topbar-title { font-size: 17px; font-weight: 700; }
.adm-whoami { font-size: 12.5px; color: #6b6e87; background:#f0f1f8; padding: 6px 12px; border-radius: 20px; }
.adm-whoami .adm-role-badge { margin-left: 6px; }
.adm-content { padding: 24px 28px 60px; }

/* KPIカード */
.adm-kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 22px; }
.adm-kpi { background: #fff; border: 1px solid #ececf5; border-radius: 14px; padding: 16px 18px; }
.adm-kpi-label { font-size: 12px; color: #8a8db0; margin-bottom: 6px; display:flex; align-items:center; gap:6px; }
.adm-kpi-value { font-size: 26px; font-weight: 800; letter-spacing: -0.5px; }
.adm-kpi-sub { font-size: 11.5px; color: #9a9cb5; margin-top: 4px; }
.adm-kpi-accent .adm-kpi-value { color: #6366f1; }

/* セクション */
.adm-section { background:#fff; border:1px solid #ececf5; border-radius:14px; padding: 18px 20px; margin-bottom: 18px; }
.adm-section-title { font-size: 14px; font-weight: 700; margin-bottom: 14px; display:flex; align-items:center; gap: 8px; }
.adm-provider-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.adm-provider-card { border:1px solid #ececf5; border-radius:11px; padding: 14px; text-align:center; }
.adm-provider-card .pv-icon { font-size: 22px; margin-bottom: 6px; }
.adm-provider-card .pv-count { font-size: 22px; font-weight: 800; }
.adm-provider-card .pv-label { font-size: 12px; color:#8a8db0; }
.pv-google .pv-icon { color:#ea4335; }
.pv-line .pv-icon { color:#06c755; }
.pv-email .pv-icon { color:#6366f1; }

/* 簡易バーチャート */
.adm-chart { display:flex; align-items:flex-end; gap: 6px; height: 120px; padding-top: 10px; }
.adm-chart-bar { flex:1; background: linear-gradient(180deg,#8b5cf6,#6366f1); border-radius: 5px 5px 0 0; min-height: 3px; position: relative; }
.adm-chart-bar span { position:absolute; top:-18px; left:50%; transform:translateX(-50%); font-size:10px; color:#6b6e87; }
.adm-chart-labels { display:flex; gap:6px; margin-top:6px; }
.adm-chart-labels div { flex:1; text-align:center; font-size:9.5px; color:#9a9cb5; }

/* テーブル */
.adm-toolbar { display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-bottom: 14px; }
.adm-input { border:1px solid #d8d9e8; border-radius:9px; padding: 8px 12px; font-size: 13px; font-family:inherit; outline:none; }
.adm-input:focus { border-color:#6366f1; }
.adm-select { border:1px solid #d8d9e8; border-radius:9px; padding: 8px 12px; font-size: 13px; font-family:inherit; background:#fff; cursor:pointer; }
.adm-table-wrap { background:#fff; border:1px solid #ececf5; border-radius:14px; overflow:hidden; }
.adm-table { width:100%; border-collapse: collapse; font-size: 13px; }
.adm-table th { background:#f7f8fc; text-align:left; padding: 11px 14px; font-weight:600; color:#6b6e87; font-size:12px; white-space:nowrap; border-bottom:1px solid #ececf5; }
.adm-table td { padding: 11px 14px; border-bottom:1px solid #f2f3f9; vertical-align: middle; }
.adm-table tr:last-child td { border-bottom:none; }
.adm-table tr:hover td { background:#fafbff; }
.adm-table .adm-row-click { cursor:pointer; }

/* バッジ */
.adm-badge { display:inline-block; padding: 2px 9px; border-radius: 20px; font-size: 11px; font-weight:600; }
.adm-badge-google { background:#fde8e6; color:#c5221f; }
.adm-badge-line { background:#e3f9ec; color:#04864b; }
.adm-badge-email { background:#eef0ff; color:#4f46e5; }
.adm-badge-admin { background:#fce8ff; color:#a21caf; }
.adm-badge-editor { background:#fff3da; color:#a15c00; }
.adm-badge-viewer { background:#eef1f6; color:#5b6172; }
.adm-badge-ok { background:#e3f9ec; color:#04864b; }
.adm-badge-warn { background:#fff3da; color:#a15c00; }
.adm-badge-muted { background:#eef1f6; color:#5b6172; }

/* ボタン */
.adm-btn { border:none; border-radius:9px; padding: 8px 14px; font-size: 13px; font-weight:600; cursor:pointer; font-family:inherit; }
.adm-btn-primary { background: linear-gradient(135deg,#6366f1,#8b5cf6); color:#fff; }
.adm-btn-danger { background:#fee2e2; color:#dc2626; }
.adm-btn-danger:hover { background:#fecaca; }
.adm-btn-ghost { background:#f0f1f8; color:#4b4e63; }
.adm-btn-sm { padding: 5px 10px; font-size:12px; }

.adm-empty { text-align:center; padding: 40px; color:#9a9cb5; font-size: 13px; }
.adm-loading { text-align:center; padding: 40px; color:#9a9cb5; }
.adm-muted { color:#9a9cb5; font-size:12px; }

/* 詳細モーダル */
.adm-modal-back { position:fixed; inset:0; background:rgba(15,15,35,.55); backdrop-filter: blur(3px); z-index: 9000; display:flex; align-items:center; justify-content:center; padding: 20px; }
.adm-modal { background:#fff; border-radius:16px; width:100%; max-width: 560px; max-height: 88vh; overflow-y:auto; padding: 24px; box-shadow: 0 24px 60px rgba(0,0,0,.3); }
.adm-modal h3 { font-size: 17px; margin: 0 0 4px; }
.adm-modal-close { float:right; background:none; border:none; font-size:18px; color:#9a9cb5; cursor:pointer; }
.adm-detail-row { display:flex; justify-content:space-between; padding: 8px 0; border-bottom:1px solid #f2f3f9; font-size: 13px; }
.adm-detail-row .k { color:#8a8db0; }
.adm-detail-row .v { font-weight:600; text-align:right; }
/* ユーザー区分（個人/法人）切替トグル */
.adm-role-switch { display:inline-flex; gap:4px; }
.adm-roletoggle {
  display:inline-flex; align-items:center; gap:4px;
  padding:4px 12px; border:1px solid #d8d9e6; border-radius:999px;
  background:#fff; color:#8a8db0; font-size:12px; font-weight:700; cursor:pointer;
  transition: all .15s;
}
.adm-roletoggle:hover { border-color:#6366f1; color:#6366f1; }
.adm-roletoggle.active { background:#6366f1; border-color:#6366f1; color:#fff; }
.adm-roletoggle.active:hover { color:#fff; }
.adm-roletoggle-sm { padding:3px 9px; font-size:11px; }
.adm-roletoggle-sm i { font-size:10px; }
/* 区分バッジ（一覧表示用・変更不可。変更は名前クリック→詳細から） */
.adm-kind-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 11px; border-radius:999px; font-size:12px; font-weight:700;
}
.adm-kind-badge i { font-size:10px; }
.adm-kind-owner { background:#eef0fb; color:#5b5fc7; }
.adm-kind-b2b { background:#fdeede; color:#c2761a; }
.adm-kind-client { background:#e6f6f0; color:#1f9d6b; }
/* ソート可能なテーブルヘッダー */
.adm-th-sort { cursor:pointer; user-select:none; white-space:nowrap; }
.adm-th-sort:hover { color:#6366f1; }
.adm-sort-icon { margin-left:3px; font-size:10px; color:#c2c4d8; }
.adm-sort-icon.active { color:#6366f1; }
.adm-sublist { margin-top: 8px; }
.adm-sublist-item { font-size:12.5px; padding:6px 10px; background:#f7f8fc; border-radius:8px; margin-bottom:5px; display:flex; justify-content:space-between; }

.adm-access-denied { max-width: 460px; margin: 80px auto; text-align:center; background:#fff; border:1px solid #ececf5; border-radius:16px; padding: 40px; }
.adm-access-denied i { font-size: 40px; color:#cbd0e0; margin-bottom: 16px; }
.adm-access-denied h2 { font-size: 18px; margin-bottom: 8px; }
.adm-access-denied p { color:#6b6e87; font-size: 13.5px; line-height: 1.7; }
.adm-access-denied a { color:#6366f1; }

@media (max-width: 820px) {
  .adm-sidebar { width: 64px; }
  .adm-brand-name, .adm-brand-sub, .adm-nav-item span, .adm-foot-link span { display:none; }
  .adm-nav-item { justify-content:center; }
  .adm-main { margin-left: 64px; }
  .adm-kpi-grid { grid-template-columns: repeat(2,1fr); }
  .adm-provider-grid { grid-template-columns: 1fr; }
}

/* ============================================
   空き枠カレンダー (Calendar)
   ============================================ */
.cal-monthnav { display:flex; align-items:center; gap:8px; }
.cal-navbtn {
  width:32px; height:32px; border:1px solid var(--color-border-tertiary);
  background:var(--color-background-primary); border-radius:var(--border-radius-md);
  cursor:pointer; color:var(--color-text-secondary); font-size:13px; transition:.15s;
}
.cal-navbtn:hover { background:var(--color-background-secondary); color:var(--color-text-primary); }
.cal-monthlabel { font-weight:700; font-size:15px; min-width:118px; text-align:center; }
.cal-todaybtn {
  margin-left:4px; padding:6px 12px; border:1px solid var(--color-border-tertiary);
  background:var(--color-background-primary); border-radius:var(--border-radius-md);
  cursor:pointer; font-size:12px; color:var(--color-text-secondary); transition:.15s;
}
.cal-todaybtn:hover { background:var(--color-background-secondary); color:var(--color-text-primary); }

.cal-legend { display:flex; flex-wrap:wrap; gap:16px; font-size:12px; margin-bottom:14px; color:var(--color-text-secondary); align-items:center; }
.cal-legend > span { display:inline-flex; align-items:center; gap:5px; }
.cal-swatch { display:inline-block; width:11px; height:11px; border-radius:3px; }
.cal-sw-available { background:#9FE1CB; }
.cal-sw-tentative { background:#FAC775; }
.cal-sw-confirmed { background:#F5A38B; }
.cal-legend-hint { color:var(--color-text-tertiary); margin-left:auto; }

.cal-weekhead { display:grid; grid-template-columns:repeat(7,1fr); gap:6px; margin-bottom:6px; }
.cal-weekday { text-align:center; font-size:11px; font-weight:600; color:var(--color-text-secondary); padding:4px 0; }
.cal-weekday.cal-sun { color:#C2410C; }
.cal-weekday.cal-sat { color:#0C447C; }

.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:6px; }
.cal-cell {
  min-height:78px; border:1px solid var(--color-border-tertiary);
  border-radius:var(--border-radius-md); padding:4px; background:var(--color-background-primary);
  cursor:pointer; transition:.12s; display:flex; flex-direction:column; overflow:hidden;
}
.cal-cell:hover { border-color:var(--color-accent); box-shadow:0 2px 8px rgba(216,90,48,.12); }
.cal-cell.cal-empty { border:none; background:transparent; cursor:default; }
.cal-cell.cal-empty:hover { box-shadow:none; }
.cal-cell.cal-today { border-color:var(--color-accent); border-width:2px; }
.cal-daynum { font-size:12px; font-weight:600; color:var(--color-text-primary); margin-bottom:3px; line-height:1; }
.cal-daynum.cal-sun { color:#C2410C; }
.cal-daynum.cal-sat { color:#0C447C; }

.cal-slots { display:flex; flex-direction:column; gap:3px; flex:1; }
.cal-slot { border-radius:4px; padding:2px 4px; font-size:9px; line-height:1.25; display:flex; flex-direction:column; gap:1px; overflow:hidden; }
.cal-slot-tag { font-size:8px; font-weight:700; opacity:.7; }
.cal-slot-txt { font-size:9px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cal-half { flex:1; min-height:18px; }
.cal-allday { flex:1; justify-content:center; align-items:flex-start; min-height:46px; }
.cal-none { background:var(--color-background-secondary); color:var(--color-text-tertiary); }
.cal-available { background:#D6F2E8; color:#085041; }
.cal-tentative { background:#FCE7C5; color:#633806; }
.cal-confirmed { background:#FBD9CD; color:#9A2C0E; }
.cal-gmark { font-size:7px; margin-left:3px; opacity:.85; }

/* Googleカレンダー連携バー */
.gcal-bar { margin-bottom:14px; }
.gcal-card { display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap;
  border:1px solid var(--color-border-tertiary); border-radius:var(--border-radius-md);
  background:var(--color-background-primary); padding:14px 16px; }
.gcal-card.gcal-connected { border-color:#bbf7d0; background:#f0fdf4; }
.gcal-card.gcal-muted { color:var(--color-text-tertiary); font-size:12px; justify-content:flex-start; }
.gcal-info { display:flex; align-items:flex-start; gap:12px; flex:1; min-width:200px; }
.gcal-gicon { font-size:20px; color:#4285F4; margin-top:2px; }
.gcal-title { font-weight:700; font-size:13px; color:var(--color-text-primary); margin-bottom:2px; display:flex; align-items:center; gap:6px; }
.gcal-desc { font-size:11px; color:var(--color-text-secondary); line-height:1.6; }
.gcal-actions { display:flex; gap:8px; flex-wrap:wrap; }
.gcal-btn { font-size:12px; padding:8px 14px; white-space:nowrap; }
.gcal-danger { color:#dc2626; }
.gcal-danger:hover { background:#fef2f2; }
.cal-gnote { font-size:11px; line-height:1.6; color:#1e40af; background:#eff6ff; border:1px solid #bfdbfe;
  border-radius:8px; padding:9px 12px; margin-bottom:14px; }

/* カレンダー編集モーダル */
/* 外枠(.gc-modal)のpaddingを打ち消し、ヘッダ/ボディ/フッタが全幅を使うようにする。
   これにより中身がはみ出して横スクロールが出るのを防ぐ。
   .gc-modal-cal クラス指定と :has() の両方で確実に効かせる */
.gc-modal-cal,
.gc-modal:has(.cal-modal) { padding: 0; max-width: 520px; overflow: hidden; }
.cal-modal { width: 100%; box-sizing: border-box; }
.gc-modal-head { display:flex; align-items:center; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--color-border-tertiary); }
.gc-modal-x { background:none; border:none; cursor:pointer; font-size:18px; color:var(--color-text-tertiary); width:30px; height:30px; border-radius:6px; transition:.15s; }
.gc-modal-x:hover { background:var(--color-background-secondary); color:var(--color-text-primary); }
.cal-modal-body { padding:18px 20px; }
.cal-mode-tabs { display:flex; gap:0; margin-bottom:18px; border:1px solid var(--color-border-tertiary); border-radius:var(--border-radius-md); overflow:hidden; }
.cal-mode-tab { flex:1; padding:8px; background:var(--color-background-primary); border:none; cursor:pointer; font-size:12px; color:var(--color-text-secondary); transition:.15s; }
.cal-mode-tab + .cal-mode-tab { border-left:1px solid var(--color-border-tertiary); }
.cal-mode-tab.active { background:var(--color-accent); color:#fff; font-weight:600; }
.cal-edit-row { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:8px; flex-wrap:wrap; }
.cal-edit-label { font-size:13px; font-weight:600; color:var(--color-text-primary); display:flex; align-items:center; gap:6px; }
.cal-edit-label i { color:var(--color-text-tertiary); }
.cal-st-group { display:flex; gap:5px; flex-wrap:wrap; }
.cal-st-btn { padding:5px 10px; border:1px solid var(--color-border-tertiary); background:var(--color-background-primary); border-radius:16px; cursor:pointer; font-size:11px; color:var(--color-text-secondary); transition:.12s; }
.cal-st-btn:hover { border-color:var(--color-text-secondary); }
.cal-st-btn.active.cal-st-available { background:#D6F2E8; border-color:#085041; color:#085041; font-weight:600; }
.cal-st-btn.active.cal-st-tentative { background:#FCE7C5; border-color:#633806; color:#633806; font-weight:600; }
.cal-st-btn.active.cal-st-confirmed { background:#FBD9CD; border-color:#9A2C0E; color:#9A2C0E; font-weight:600; }
.cal-st-btn.active.cal-st-clear { background:var(--color-text-secondary); border-color:var(--color-text-secondary); color:#fff; font-weight:600; }
.cal-note { width:100%; box-sizing:border-box; padding:7px 10px; border:1px solid var(--color-border-tertiary); border-radius:var(--border-radius-md); font-size:12px; margin-top:4px; }
.cal-note:focus { outline:none; border-color:var(--color-accent); }
.cal-modal-foot { display:flex; align-items:center; gap:8px; padding:14px 20px; border-top:1px solid var(--color-border-tertiary); flex-wrap:wrap; }

/* 時刻ベース編集UI */
.cal-modal-body { max-height:62vh; overflow-y:auto; }
.cal-quick { display:flex; flex-wrap:wrap; align-items:center; gap:6px; margin-bottom:14px; padding-bottom:14px; border-bottom:1px dashed var(--color-border-tertiary); }
.cal-quick-lbl { font-size:11px; color:var(--color-text-secondary); width:100%; margin-bottom:2px; }
/* クイック追加ボタンは折り返して常に枠内に収める（横はみ出し防止） */
.cal-quick-btn { flex:1 1 auto; min-width:0; white-space:nowrap; padding:6px 10px; border:1px solid var(--color-border-tertiary); background:var(--color-background-primary); border-radius:8px; cursor:pointer; font-size:11px; color:var(--color-text-secondary); transition:.12s; }
.cal-quick-btn:hover { border-color:var(--color-accent); color:var(--color-accent); }
.cal-quick-btn i { margin-right:3px; }
.cal-slot-row { border:1px solid var(--color-border-tertiary); border-radius:var(--border-radius-md); padding:10px 12px; margin-bottom:10px; background:var(--color-background-primary); }
.cal-slot-row-top { display:flex; align-items:center; gap:6px; margin-bottom:8px; flex-wrap:wrap; }
.cal-time { padding:5px 8px; border:1px solid var(--color-border-tertiary); border-radius:6px; font-size:13px; color:var(--color-text-primary); }
.cal-time:focus { outline:none; border-color:var(--color-accent); }
.cal-time-sep { color:var(--color-text-tertiary); font-size:13px; }
.cal-row-del { margin-left:auto; background:none; border:none; cursor:pointer; color:var(--color-text-tertiary); width:26px; height:26px; border-radius:6px; transition:.12s; }
.cal-row-del:hover { background:#fef2f2; color:#dc2626; }
.cal-grow-tag { font-size:10px; color:#4285F4; background:#e8f0fe; padding:2px 7px; border-radius:10px; white-space:nowrap; }
.cal-grow-tag i { margin-right:3px; }
.cal-add-btn { width:100%; padding:9px; border:1px dashed var(--color-border-tertiary); background:none; border-radius:var(--border-radius-md); cursor:pointer; font-size:12px; color:var(--color-text-secondary); transition:.12s; }
.cal-add-btn:hover { border-color:var(--color-accent); color:var(--color-accent); background:var(--color-background-secondary); }
.cal-add-btn i { margin-right:4px; }
.cal-empty-hint { font-size:12px; color:var(--color-text-tertiary); text-align:center; padding:18px 10px; line-height:1.6; }
/* セル: 複数スロットを縦に積む */
.cal-slot { margin-bottom:2px; }
.cal-slots { gap:2px; }
.w-btn-ghost { padding:8px 14px; border:1px solid var(--color-border-tertiary); background:var(--color-background-primary); border-radius:var(--border-radius-md); cursor:pointer; font-size:12px; color:var(--color-text-secondary); transition:.15s; }
.w-btn-ghost:hover { background:var(--color-background-secondary); color:var(--color-text-primary); }

@media (max-width: 820px) {
  .cal-cell { min-height:64px; }
  .cal-legend-hint { margin-left:0; width:100%; }
  .cal-monthnav { flex-wrap:wrap; }
}

/* ===== パスワード再設定モーダル / 完了表示 ===== */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 18, 30, 0.55);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.2rem;
  z-index: 1000;
}
.modal-card {
  position: relative;
  background: #fff;
  border-radius: 18px;
  padding: 2rem 1.8rem 1.8rem;
  width: 100%;
  max-width: 420px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22);
  animation: modal-pop 0.18s ease-out;
}
@keyframes modal-pop {
  from { opacity: 0; transform: translateY(8px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.modal-close {
  position: absolute;
  top: 0.9rem;
  right: 1rem;
  background: none;
  border: none;
  font-size: 1.2rem;
  color: #9a9cb5;
  cursor: pointer;
  line-height: 1;
  padding: 0.2rem;
}
.modal-close:hover { color: #555; }
.forgot-done {
  text-align: center;
  padding: 1rem 0 0.4rem;
}

/* ============================================
   法人枠（B2B）スタイル
   ============================================ */
/* サイドメニューの法人項目 */
.w-side-b2b span i { color: var(--color-accent); }

/* プランバッジ */
.b2b-plan-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; padding: 5px 12px; border-radius: 999px;
}
.b2b-badge-basic { background: var(--color-background-tertiary); color: var(--color-text-secondary); }
.b2b-badge-pro { background: var(--color-accent-light); color: var(--color-accent-text); }
.b2b-badge-ent { background: var(--color-purple-bg); color: var(--color-purple-fg); }

/* ダッシュボードの2カラム */
.b2b-dash-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 8px; }
@media (max-width: 860px) { .b2b-dash-cols { grid-template-columns: 1fr; } }
.b2b-fav-mini {
  display: flex; gap: 10px; align-items: center; padding: 8px;
  border: 1px solid var(--color-border-tertiary); border-radius: var(--border-radius-md);
  margin-bottom: 8px; cursor: pointer; transition: background .15s;
}
.b2b-fav-mini:hover { background: var(--color-background-secondary); }

/* お気に入りグリッド */
.b2b-fav-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
.b2b-fav-card { padding: 16px; }

/* お気に入り：ツールバー（タグフィルター＋表示切替） */
.fav-toolbar {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  flex-wrap: wrap; margin-bottom: 14px;
}
.fav-filters { display: flex; flex-wrap: wrap; gap: 6px; flex: 1; min-width: 0; }
.fav-filter-chip {
  font-size: 12px; padding: 5px 12px; border-radius: 999px; cursor: pointer;
  border: 1px solid var(--color-border-tertiary); background: var(--color-background-secondary);
  color: var(--color-text-secondary); transition: .12s; white-space: nowrap;
}
.fav-filter-chip:hover { border-color: var(--color-accent); color: var(--color-accent); }
.fav-filter-chip.active { background: var(--color-accent); border-color: var(--color-accent); color: #fff; }
/* 表示切替トグル */
.fav-viewtoggle { display: inline-flex; border: 1px solid var(--color-border-tertiary); border-radius: 8px; overflow: hidden; flex-shrink: 0; }
.fav-view-btn {
  background: var(--color-background-secondary); border: none; cursor: pointer;
  padding: 7px 12px; font-size: 13px; color: var(--color-text-tertiary); transition: .12s;
}
.fav-view-btn + .fav-view-btn { border-left: 1px solid var(--color-border-tertiary); }
.fav-view-btn:hover { color: var(--color-text-primary); }
.fav-view-btn.active { background: var(--color-accent); color: #fff; }

/* タグチップ（一覧表示用） */
.fav-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
.fav-tag {
  font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 999px;
  background: rgba(196, 92, 47, .1); color: var(--color-accent);
}
.fav-tag-sm { font-size: 9px; padding: 1px 6px; }

/* リスト表示 */
.fav-listview { display: flex; flex-direction: column; gap: 8px; }
.fav-row {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  border: 1px solid var(--color-border-tertiary); border-radius: var(--border-radius-md);
  background: var(--color-background-primary);
}
.fav-row-main { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 0; cursor: pointer; }
.fav-row-name { font-size: 13px; font-weight: 600; }
.fav-row-meta { font-size: 11px; font-weight: 400; color: var(--color-text-tertiary); margin-left: 4px; }
.fav-row-actions { display: flex; gap: 4px; flex-shrink: 0; }
.fav-iconbtn { font-size: 13px; padding: 6px 9px; }

/* タグ編集モーダル */
.fav-tag-editing { display: flex; flex-wrap: wrap; gap: 6px; min-height: 32px; padding: 8px; border: 1px solid var(--color-border-tertiary); border-radius: var(--border-radius-md); background: var(--color-background-secondary); }
.fav-tag-pill {
  display: inline-flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 600;
  padding: 4px 6px 4px 10px; border-radius: 999px; background: rgba(196, 92, 47, .12); color: var(--color-accent);
}
.fav-tag-pill button { background: none; border: none; color: var(--color-accent); cursor: pointer; font-size: 15px; line-height: 1; padding: 0 2px; }
.fav-tag-presets { display: flex; flex-wrap: wrap; gap: 6px; }
.fav-tag-preset {
  font-size: 12px; padding: 5px 12px; border-radius: 999px; cursor: pointer;
  border: 1px dashed var(--color-border-secondary); background: transparent; color: var(--color-text-secondary); transition: .12s;
}
.fav-tag-preset:hover { border-color: var(--color-accent); color: var(--color-accent); border-style: solid; }

/* 一斉送信 2カラム */
.b2b-bc-cols { display: grid; grid-template-columns: 1.2fr 1fr; gap: 24px; align-items: start; }
@media (max-width: 920px) { .b2b-bc-cols { grid-template-columns: 1fr; } }
.b2b-bc-recipients {
  border: 1px solid var(--color-border-tertiary); border-radius: var(--border-radius-md);
  padding: 12px;
}

/* ロック表示（無料プランで一斉送信不可のとき） */
.b2b-locked {
  text-align: center; padding: 48px 24px; border: 2px dashed var(--color-border-tertiary);
  border-radius: var(--border-radius-lg); background: var(--color-background-secondary);
}
.b2b-locked i { font-size: 36px; color: var(--color-accent); opacity: .7; margin-bottom: 16px; }
.b2b-locked h2 { font-size: 17px; margin: 0 0 8px; color: var(--color-text-primary); }
.b2b-locked p { font-size: 13px; color: var(--color-text-secondary); line-height: 1.7; margin: 0 0 20px; }

/* 料金カードグリッド */
.b2b-price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 8px; }
@media (max-width: 900px) { .b2b-price-grid { grid-template-columns: 1fr; } }
.b2b-price-card {
  position: relative; border: 1px solid var(--color-border-tertiary);
  border-radius: var(--border-radius-lg); padding: 24px 20px; background: #fff;
  display: flex; flex-direction: column;
}
.b2b-price-hl { border: 2px solid var(--color-accent); box-shadow: 0 8px 24px rgba(216,90,48,.12); }
.b2b-price-current { background: var(--color-background-secondary); }
.b2b-price-ribbon {
  position: absolute; top: -11px; left: 50%; transform: translateX(-50%);
  background: var(--color-accent); color: #fff; font-size: 11px; font-weight: 700;
  padding: 4px 14px; border-radius: 999px;
}
.b2b-price-currenttag {
  position: absolute; top: 12px; right: 12px; background: var(--color-success-bg);
  color: var(--color-success-fg); font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 999px;
}
.b2b-price-name { font-size: 14px; font-weight: 700; color: var(--color-text-primary); }
.b2b-price-amount { font-size: 28px; font-weight: 800; color: var(--color-accent); margin: 8px 0 2px; }
.b2b-price-tax { font-size: 12px; font-weight: 500; color: var(--color-text-tertiary); margin-left: 4px; }
.b2b-price-tagline { font-size: 12px; color: var(--color-text-secondary); line-height: 1.6; min-height: 38px; }
.b2b-price-perks { list-style: none; padding: 0; margin: 16px 0; flex: 1; }
.b2b-price-perks li { font-size: 12px; color: var(--color-text-primary); line-height: 1.6; margin-bottom: 8px; }
.b2b-price-perks li i { color: #2e9e5b; margin-right: 6px; }
.b2b-price-action { margin-top: auto; }

/* 機能比較表 */
.b2b-compare th, .b2b-compare td { padding: 10px 12px; }

/* ============================================
   サインアップ：アカウント種別トグル（個人/法人）
   ============================================ */
.acct-type-toggle { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.acct-type-btn {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 14px 10px; border: 1.5px solid var(--color-border-tertiary);
  border-radius: var(--border-radius-md); background: #fff; cursor: pointer;
  transition: all .15s; color: var(--color-text-secondary);
}
.acct-type-btn i { font-size: 18px; }
.acct-type-btn span { font-size: 13px; font-weight: 700; color: var(--color-text-primary); }
.acct-type-btn small { font-size: 10px; color: var(--color-text-tertiary); }
.acct-type-btn:hover { border-color: var(--color-accent); }
.acct-type-btn.active {
  border-color: var(--color-accent); background: var(--color-accent-light);
}
.acct-type-btn.active i, .acct-type-btn.active span { color: var(--color-accent-text); }
