/* ============================================
   驛｢・ｧ繝ｻ・､驛｢譎冗函・趣ｽｦ驛｢譎冗樟郢晢ｽｯ驛｢譎樊束雋よ・豼､繝ｻ・ｹ驛｢・ｧ繝ｻ・ｷ驛｢・ｧ繝ｻ・ｹ驛｢譎｢・ｿ・ｽ・弱・- 驛｢譎｢・ｽ・｡驛｢・ｧ繝ｻ・､驛｢譎｢・ｽ・ｳ驛｢・ｧ繝ｻ・ｹ驛｢・ｧ繝ｻ・ｿ驛｢・ｧ繝ｻ・､驛｢譎｢・ｽ・ｫ
   驛｢・ｧ繝ｻ・､驛｢譎冗函・趣ｽｦ驛｢譎冗樟郢晢ｽｯ驛｢譎樊束雋よ・豼､繝ｻ・ｹ驛｢・ｧ繝ｻ・ｷ驛｢・ｧ繝ｻ・ｹ驛｢譁溘・- 驛｢譎｢・ｽ・｡驛｢・ｧ繝ｻ・､驛｢譎｢・ｽ・ｳ驛｢・ｧ繝ｻ・ｹ驛｢・ｧ繝ｻ・ｿ驛｢・ｧ繝ｻ・､驛｢譎｢・ｽ・ｫ
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

/* 髫ｨ髷倥℃髫ｨ髷倥℃ 驛｢・ｧ繝ｻ・ｫ驛｢譎｢・ｽ・ｩ驛｢譎｢・ｽ・ｼ驛｢譎冗樟驛｢・ｧ繝ｻ・ｯ驛｢譎｢・ｽ・ｳ 髫ｨ髷倥℃髫ｨ髷倥℃ */
:root {
  --bg-base: #1e1e24;
  --bg-panel: #26262d;
  --bg-card: #26262d;
  --bg-card-hover: #2e2e36;
  --bg-sidebar: #18181c;
  --bg-input: #1e1e24;

  --border-subtle: rgba(255, 255, 255, 0.05);
  --border-mid: rgba(255, 255, 255, 0.08);
  --border-accent: rgba(92, 124, 250, 0.3);

  --accent-cyan: #5c7cfa;
  --accent-green: #40c057;
  --accent-purple: #9775fa;
  --accent-orange: #ff922b;
  --accent-red: #fa5252;
  --accent-yellow: #fcc419;

  --text-primary: #e0e0e6;
  --text-secondary: #90909c;
  --text-muted: #5e5e66;
  --text-accent: #5c7cfa;

  --shadow-card: 0 2px 6px rgba(0, 0, 0, 0.15);
  --shadow-glow: none;
  --shadow-modal: 0 8px 32px rgba(0, 0, 0, 0.4);

  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 20px;

  --sidebar-width: 240px;
  --header-height: 60px;

  --transition: 0.2s ease;
  --transition-slow: 0.35s cubic-bezier(.4, 0, .2, 1);
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎｢・ｽ・ｪ驛｢・ｧ繝ｻ・ｻ驛｢譎｢・ｿ・ｽ郢晢ｽｨ驛｢譎｢・ｽ・ｻ驛｢譎冗函繝ｻ・ｽ驛｢・ｧ繝ｻ・ｹ 髫ｨ貂可髫ｨ貂可 */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 14px;
  scroll-behavior: smooth;
}

body {
  font-family: 'Noto Sans JP', 'Inter', sans-serif;
  background: var(--bg-base);
  color: var(--text-primary);
  line-height: 1.6;
  min-height: 100vh;
  width: 100%;
  overflow-x: hidden;
  position: relative;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢・ｧ繝ｻ・ｹ驛｢・ｧ繝ｻ・ｯ驛｢譎｢・ｽ・ｭ驛｢譎｢・ｽ・ｼ驛｢譎｢・ｽ・ｫ驛｢譎√・繝ｻ・ｽ 髫ｨ貂可髫ｨ貂可 */
::-webkit-scrollbar {
  width: 5px;
  height: 5px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: rgba(0, 212, 255, 0.2);
  border-radius: 99px;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 212, 255, 0.4);
}

/* 髫ｨ貂可髫ｨ貂可 鬮｢・ｭ隴ｴ・ｧ陷搾ｽｹ驛｢・ｧ繝ｻ・ｰ驛｢譎｢・ｽ・ｪ驛｢譎｢・ｿ・ｽ郢晢ｽｩ驛｢譏懶ｽｻ・｣邵ｺ・｡驛｢譎｢・ｽ・ｼ驛｢譎｢・ｽ・ｳ 髫ｨ貂可髫ｨ貂可 */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(0, 212, 255, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 212, 255, 0.03) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
  z-index: 0;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎｢・ｽ・ｬ驛｢・ｧ繝ｻ・､驛｢・ｧ繝ｻ・｢驛｢・ｧ繝ｻ・ｦ驛｢譎｢・ｿ・ｽ 髫ｨ貂可髫ｨ貂可 */
.layout {
  display: flex;
  min-height: 100vh;
  position: relative;
  z-index: 1;
}

/* 髫ｨ髷倥℃髫ｨ髷倥℃ 驛｢・ｧ繝ｻ・ｵ驛｢・ｧ繝ｻ・､驛｢譎擾ｽｳ・ｨ郢晢ｽｰ驛｢譎｢・ｽ・ｼ 髫ｨ髷倥℃髫ｨ髷倥℃ */
.sidebar {
  width: var(--sidebar-width);
  height: 100vh;
  background: var(--bg-sidebar);
  border-right: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 100;
  transition: transform var(--transition-slow);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--border-subtle) transparent;
}
.sidebar::-webkit-scrollbar {
  width: 4px;
}
.sidebar::-webkit-scrollbar-thumb {
  background: var(--border-subtle);
  border-radius: 4px;
}


.sidebar-logo {
  padding: 20px 18px 16px;
  border-bottom: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  gap: 10px;
}

.sidebar-logo .logo-icon {
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, var(--accent-cyan), var(--accent-green));
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}

.sidebar-logo .logo-text {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--text-primary);
  line-height: 1.3;
}

.sidebar-logo .logo-text span {
  display: block;
  font-size: 9px;
  color: var(--text-muted);
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* 驛｢譎｢・ｽ・ｦ驛｢譎｢・ｽ・ｼ驛｢・ｧ繝ｻ・ｶ驛｢譎｢・ｽ・ｼ髫ｲ・ｰ繝ｻ・ｽ繝ｻ・ｽ繝ｻ・ｱ驛｢譎√・繝ｻ・ｽ */
.sidebar-user-container {
  position: relative;
  padding: 8px;
  border-bottom: 1px solid var(--border-subtle);
}

.sidebar-user {
  padding: 8px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  border-radius: var(--radius-md);
  transition: background var(--transition);
}

.sidebar-user:hover {
  background: rgba(255, 255, 255, 0.05);
}

.user-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-purple), var(--accent-cyan));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 600;
  flex-shrink: 0;
}

.user-info {
  min-width: 0;
  flex: 1;
}

.user-info .user-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.user-info .user-role {
  font-size: 10px;
  color: var(--text-secondary);
}

.menu-arrow {
  font-size: 18px;
  color: var(--text-muted);
  transition: transform var(--transition);
}

.sidebar-user-container.active .menu-arrow {
  transform: rotate(180deg);
}

/* 驛｢譎擾ｽｳ・ｨ・取ｺｽ・ｹ譎会ｽｹ譏ｶ縺朱Δ・ｧ繝ｻ・ｦ驛｢譎｢・ｽ・ｳ驛｢譎｢・ｽ・｡驛｢譏懶ｽｹ譁溽､ｼ・ｹ譎｢・ｽ・ｼ */
.user-dropdown {
  position: absolute;
  top: calc(100% - 4px);
  left: 8px;
  right: 8px;
  background: #2a2a32;
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-md);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
  z-index: 110;
  display: none;
  overflow: hidden;
  animation: slideDown 0.2s ease-out;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.sidebar-user-container.active .user-dropdown {
  display: block;
}

.dropdown-item {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: 12.5px;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition);
  text-align: left;
}

.dropdown-item span {
  font-size: 18px;
}

.dropdown-item:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-primary);
}

.dropdown-item.logout {
  color: var(--accent-red);
}

.dropdown-item.logout:hover {
  background: rgba(250, 82, 82, 0.1);
}

.dropdown-divider {
  height: 1px;
  background: var(--border-subtle);
  margin: 4px 0;
}

/* 驛｢・ｧ繝ｻ・ｵ驛｢・ｧ繝ｻ・､驛｢譎擾ｽｳ・ｨ郢晢ｽｰ驛｢譎｢・ｽ・ｼ驛｢譎会ｽｿ・ｫ郢晢ｽｳ */
.sidebar-nav {
  flex: 1;
  padding: 12px 8px;
  overflow-y: auto; /* 郢ｧ・ｹ郢ｧ・ｯ郢晢ｽｭ郢晢ｽｼ郢晢ｽｫ陷ｿ・ｯ髢ｭ・ｽ邵ｺ・ｫ */
  min-height: 0;
}

.nav-section {
  margin-bottom: 20px;
}

.nav-section-label {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 0 10px;
  margin-bottom: 6px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--text-secondary);
  font-size: 12.5px;
  font-weight: 500;
  transition: all var(--transition);
  position: relative;
  text-decoration: none;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
}

.nav-item:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-primary);
}

.nav-item.active {
  background: rgba(0, 212, 255, 0.1);
  color: var(--accent-cyan);
}

.nav-item.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--accent-cyan);
  border-radius: 0 2px 2px 0;
}

.nav-item .nav-icon {
  font-size: 15px;
  width: 18px;
  text-align: center;
  flex-shrink: 0;
}

/* サイドバー通知バッジ（数字付き赤丸） */
.nav-badge {
  margin-left: auto;
  background: var(--accent-red);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  padding: 0 5px;
  /* 縦中央揃え */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  box-shadow: 0 0 8px rgba(250,82,82,0.4);
  animation: badgePop 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes badgePop {
  from { transform: scale(0); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}

/* 驛｢・ｧ繝ｻ・ｵ驛｢・ｧ繝ｻ・､驛｢譎擾ｽｳ・ｨ郢晢ｽｰ驛｢譎｢・ｽ・ｼ驛｢譎・ｽｼ譁石暮Δ・ｧ繝ｻ・ｿ驛｢譎｢・ｽ・ｼ */
.sidebar-footer {
  padding: 12px 8px;
  border-top: 1px solid var(--border-subtle);
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎｢・ｽ・｡驛｢・ｧ繝ｻ・､驛｢譎｢・ｽ・ｳ驛｢・ｧ繝ｻ・ｳ驛｢譎｢・ｽ・ｳ驛｢譎｢・ｿ・ｽ・趣ｽｦ驛｢譎｢・ｿ・ｽ 髫ｨ貂可髫ｨ貂可 */
.main-content {
  margin-left: var(--sidebar-width);
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-width: 0; /* 陝・頃・ｦ竏ｫ・ｴ・ｰ邵ｺ・ｫ郢ｧ蛹ｻ・玖濤繝ｻ繝ｻ隲｡・｡陟托ｽｵ郢ｧ蟶昜ｺ溯ｱ・ｽ｢ */
}

/* 驛｢譎渉・･郢晢ｽ｣驛｢謨鳴驛｢譎｢・ｽ・ｼ */
.topbar {
  height: var(--header-height);
  background: rgba(14, 18, 40, 0.8);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  padding: 0 24px;
  gap: 16px;
  position: sticky;
  top: 0;
  z-index: 50;
}

.topbar-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  flex: 1;
}

.topbar-title span {
  font-size: 11px;
  color: var(--text-muted);
  font-weight: 400;
  margin-left: 8px;
}

.bot-status {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: 99px;
  padding: 5px 12px;
  font-size: 11px;
  color: var(--text-secondary);
}

.bot-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent-red);
  transition: background var(--transition);
}

.bot-status-dot.online {
  background: var(--accent-green);
  box-shadow: 0 0 6px var(--accent-green);
}

/* 驛｢・ｧ繝ｻ・ｳ驛｢譎｢・ｽ・ｳ驛｢譎｢・ｿ・ｽ・趣ｽｦ驛｢譎｢・ｿ・ｽ邵ｺ鬘費ｽｹ譎｢・ｽ・ｪ驛｢・ｧ繝ｻ・｢ */
.content-area {
  flex: 1;
  padding: 28px;
  max-width: 1400px;
  min-width: 0; /* 鬩･蟠趣ｽｦ繝ｻ flex郢ｧ・｢郢ｧ・､郢昴・ﾎ堤ｸｺ謔溘・陞ｳ・ｹ邵ｺ・ｫ郢ｧ蛹ｻ笆ｲ邵ｺ・ｦ陟弱・窶ｲ郢ｧ荵昴・郢ｧ蟶昜ｺ溽ｸｺ繝ｻ*/
}

/* 髫ｨ貂可髫ｨ貂可 驛｢・ｧ繝ｻ・ｫ驛｢譎｢・ｽ・ｼ驛｢譎｢・ｿ・ｽ 髫ｨ貂可髫ｨ貂可 */
.card {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 22px;
  transition: border-color var(--transition);
}

.card:hover {
  border-color: var(--border-mid);
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border-subtle);
}

.card-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: 8px;
}

.card-title .icon {
  color: var(--accent-cyan);
  font-size: 16px;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎・鯵邵ｺ・｡驛｢譎｢・ｽ・ｳ 髫ｨ貂可髫ｨ貂可 */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: var(--radius-md);
  font-size: 12.5px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  border: none;
  transition: all var(--transition);
  text-decoration: none;
  white-space: nowrap;
}

.btn-primary {
  background: var(--accent-cyan);
  color: #fff;
}

.btn-primary:hover {
  background: #4b66df;
}

.btn-success {
  background: var(--accent-green);
  color: #fff;
}

.btn-success:hover {
  background: #33a647;
}

.btn-danger {
  background: rgba(255, 71, 87, 0.15);
  color: var(--accent-red);
  border: 1px solid rgba(255, 71, 87, 0.3);
}

.btn-danger:hover {
  background: rgba(255, 71, 87, 0.25);
}

.btn-warning {
  background: rgba(255, 140, 0, 0.15);
  color: var(--accent-orange);
  border: 1px solid rgba(255, 140, 0, 0.3);
}

.btn-warning:hover {
  background: rgba(255, 140, 0, 0.25);
}

.btn-ghost {
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--border-mid);
}

.btn-ghost:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-primary);
}

.btn-purple {
  background: var(--accent-purple);
  color: #fff;
}

.btn-purple:hover {
  background: #7d5acc;
}

.btn-sm {
  padding: 5px 10px;
  font-size: 11px;
}

.btn-lg {
  padding: 11px 22px;
  font-size: 14px;
}

.btn-icon {
  padding: 7px;
  width: 32px;
  height: 32px;
}

.btn-outline {
  background: transparent;
  color: var(--accent-cyan);
  border: 1px solid rgba(0, 212, 255, 0.4);
}

.btn-outline:hover {
  background: rgba(0, 212, 255, 0.08);
  border-color: var(--accent-cyan);
  box-shadow: 0 0 15px rgba(0, 212, 255, 0.15);
}

.btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none !important;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎・ｽｼ譁青ｰ驛｢譎｢・ｽ・ｼ驛｢譎｢・ｿ・ｽ 髫ｨ貂可髫ｨ貂可 */
.form-group {
  margin-bottom: 16px;
}

.form-label {
  display: block;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
  letter-spacing: 0.03em;
}

.form-label .required {
  color: var(--accent-red);
  margin-left: 3px;
}

.form-control {
  width: 100%;
  background: var(--bg-input);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: 13px;
  font-family: inherit;
  padding: 9px 12px;
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}

.form-control:focus {
  border-color: var(--accent-cyan);
  box-shadow: 0 0 0 3px rgba(0, 212, 255, 0.1);
}

.form-control::placeholder {
  color: var(--text-muted);
}

textarea.form-control {
  resize: vertical;
  min-height: 100px;
  line-height: 1.6;
}

.form-control-lg {
  padding: 12px 14px;
  font-size: 14px;
}

select.form-control {
  cursor: pointer;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.form-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
}

.form-hint {
  font-size: 10.5px;
  color: var(--text-muted);
  margin-top: 4px;
}

.form-check {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 12.5px;
  color: var(--text-secondary);
}

.form-check input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent-cyan);
  cursor: pointer;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎｢・ｿ・ｽ繝ｻ・ｽ驛｢譎・§・弱・髫ｨ貂可髫ｨ貂可 */
.table-wrap {
  overflow-x: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
}

thead tr {
  border-bottom: 1px solid var(--border-mid);
}

thead th {
  text-align: left;
  padding: 10px 12px;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
  white-space: nowrap;
}

tbody tr {
  border-bottom: 1px solid var(--border-subtle);
  transition: background var(--transition);
}

tbody tr:hover {
  background: rgba(255, 255, 255, 0.02);
}

/* 郢ｧ・ｿ郢昴・繝ｻ陷ｿ・ｯ髢ｭ・ｽ邵ｺ・ｪ髯ｦ繝ｻ*/
.row-linkable {
  cursor: pointer;
}

.row-linkable:hover {
  background: rgba(92, 124, 250, 0.05) !important;
}

.row-linkable td {
  min-height: 52px;
}

tbody td {
  padding: 12px 12px;
  color: var(--text-primary);
  vertical-align: middle;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎√・郢晢ｽ｣驛｢・ｧ繝ｻ・ｸ 髫ｨ貂可髫ｨ貂可 */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: 99px;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.badge-cyan {
  background: rgba(0, 212, 255, 0.12);
  color: var(--accent-cyan);
}

.badge-green {
  background: rgba(0, 255, 157, 0.12);
  color: var(--accent-green);
}

.badge-red {
  background: rgba(255, 71, 87, 0.12);
  color: var(--accent-red);
}

.badge-orange {
  background: rgba(255, 140, 0, 0.12);
  color: var(--accent-orange);
}

.badge-purple {
  background: rgba(124, 58, 255, 0.12);
  color: var(--accent-purple);
}

.badge-yellow {
  background: rgba(255, 211, 42, 0.12);
  color: var(--accent-yellow);
}

.badge-gray {
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-secondary);
}

/* 髫ｨ貂可髫ｨ貂可 驛｢・ｧ繝ｻ・ｹ驛｢譎｢・ｿ・ｽ繝ｻ・ｽ驛｢・ｧ繝ｻ・ｿ驛｢・ｧ繝ｻ・ｹ驛｢譎√・郢晢ｽ｣驛｢・ｧ繝ｻ・ｸ 髫ｨ貂可髫ｨ貂可 */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.status-badge::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢・ｧ繝ｻ・｢驛｢譎｢・ｽ・ｩ驛｢譎｢・ｽ・ｼ驛｢譎｢・ｿ・ｽ 髫ｨ貂可髫ｨ貂可 */
.alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  border-radius: var(--radius-md);
  font-size: 12.5px;
  line-height: 1.5;
  border: 1px solid transparent;
}

.alert-icon {
  font-size: 16px;
  flex-shrink: 0;
}

.alert-warning {
  background: rgba(255, 211, 42, 0.08);
  border-color: rgba(255, 211, 42, 0.2);
  color: var(--accent-yellow);
}

.alert-danger {
  background: rgba(255, 71, 87, 0.08);
  border-color: rgba(255, 71, 87, 0.2);
  color: var(--accent-red);
}

.alert-info {
  background: rgba(0, 212, 255, 0.08);
  border-color: rgba(0, 212, 255, 0.2);
  color: var(--accent-cyan);
}

.alert-success {
  background: rgba(0, 255, 157, 0.08);
  border-color: rgba(0, 255, 157, 0.2);
  color: var(--accent-green);
}

/* 髫ｨ貂可髫ｨ貂可 鬩搾ｽｨ繝ｻ・ｱ鬮ｫ・ｪ陋ｹ・ｻ邵ｺ蝣､・ｹ譎｢・ｽ・ｪ驛｢譎｢・ｿ・ｽ郢晢ｽｩ 髫ｨ貂可髫ｨ貂可 */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}

.stat-card {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: all var(--transition);
  cursor: default;
}

.stat-card:hover {
  border-color: var(--border-accent);
  box-shadow: var(--shadow-glow);
  transform: translateY(-2px);
}

.stat-label {
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 600;
}

.stat-value {
  font-size: 28px;
  font-weight: 700;
  color: var(--text-primary);
  font-family: 'JetBrains Mono', monospace;
  line-height: 1;
}

.stat-sub {
  font-size: 11px;
  color: var(--text-secondary);
}

.stat-icon {
  font-size: 20px;
  margin-bottom: 4px;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎擾ｽ｣・ｹ繝ｻ・ｽ驛｢・ｧ繝ｻ・ｸ驛｢・ｧ繝ｻ・ｻ驛｢・ｧ繝ｻ・ｯ驛｢・ｧ繝ｻ・ｷ驛｢譎｢・ｽ・ｧ驛｢譎｢・ｽ・ｳ驛｢・ｧ繝ｻ・ｿ驛｢・ｧ繝ｻ・､驛｢譎冗樟・弱・髫ｨ貂可髫ｨ貂可 */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}

.section-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: 8px;
}

.section-title .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--accent-cyan);
}

/* 髫ｨ貂可髫ｨ貂可 驛｢・ｧ繝ｻ・ｪ驛｢譎擾ｽ｣・ｹ・取ｨ抵ｽｹ譎｢・ｽ・ｼ驛｢・ｧ繝ｻ・ｷ驛｢譎｢・ｽ・ｧ驛｢譎｢・ｽ・ｳ驛｢・ｧ繝ｻ・ｹ驛｢譎｢・ｿ・ｽ郢晢ｽ｣驛｢譎・惧繝ｻ・ｼ陋ｹ・ｻ繝ｻ・ｽ驛｢・ｧ繝ｻ・ｿ驛｢譎｢・ｽ・ｳ髯樊ｻゑｽｽ・ｧ驍ｵ・ｺ鬮ｦ・ｪ繝ｻ繝ｻ・ｿ・ｽ繝ｻ・ｽ 髫ｨ貂可髫ｨ貂可 */
.op-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
}

.op-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 22px 16px;
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: all var(--transition-slow);
  color: var(--text-primary);
  font-family: inherit;
  text-align: center;
}

.op-btn:hover {
  border-color: var(--border-accent);
  background: var(--bg-card-hover);
  transform: translateY(-3px);
  box-shadow: var(--shadow-glow);
}

.op-btn.danger {
  border-color: rgba(255, 71, 87, 0.2);
}

.op-btn.danger:hover {
  border-color: var(--accent-red);
  box-shadow: 0 0 20px rgba(255, 71, 87, 0.15);
}

.op-btn.success {
  border-color: rgba(0, 255, 157, 0.2);
}

.op-btn.success:hover {
  border-color: var(--accent-green);
  box-shadow: 0 0 20px rgba(0, 255, 157, 0.15);
}

.op-btn.primary {
  border-color: rgba(0, 212, 255, 0.2);
}

.op-btn.primary:hover {
  border-color: var(--accent-cyan);
}

.op-btn.purple {
  border-color: rgba(124, 58, 255, 0.2);
}

.op-btn.purple:hover {
  border-color: var(--accent-purple);
  box-shadow: 0 0 20px rgba(124, 58, 255, 0.15);
}

.op-btn.orange {
  border-color: rgba(255, 140, 0, 0.2);
}

.op-btn.orange:hover {
  border-color: var(--accent-orange);
}

.op-btn-icon {
  font-size: 28px;
  line-height: 1;
}

.op-btn-roman {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: var(--text-muted);
}

/* TeruSleep郢晢ｽ｡郢晢ｽｳ郢晁・繝ｻ郢ｧ・ｫ郢晢ｽｼ郢昴・*/
.hq-group {
  animation: fadeInUp 0.5s ease both;
}
.hq-group + .hq-group {
  margin-top: 64px;
}
.dept-section + .dept-section {
  margin-top: 40px;
}

.hq-title {
  text-transform: uppercase;
  font-family: 'Outfit', sans-serif;
  background: linear-gradient(90deg, rgba(255,255,255,0.05) 0%, transparent 100%);
  padding: 12px 20px;
  border-radius: 4px;
}
.badge-orange {
  background: var(--accent-orange);
  color: #000;
  font-weight: 900;
}
.badge-purple {
  background: #a855f7;
  color: #fff;
}

.op-btn-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.3;
}

.op-btn-desc {
  font-size: 10px;
  color: var(--text-muted);
  line-height: 1.4;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢・ｧ繝ｻ・､驛｢譎冗函・趣ｽｦ驛｢譎冗樟・取㏍・ｹ・ｧ繝ｻ・ｹ驛｢譎｢・ｿ・ｽ 髫ｨ貂可髫ｨ貂可 */
.event-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.event-row {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  cursor: pointer;
  transition: all var(--transition);
}

.event-row:hover {
  border-color: var(--border-accent);
  background: var(--bg-card-hover);
}

.event-row-date {
  min-width: 90px;
  font-size: 11px;
  color: var(--text-secondary);
  font-family: 'JetBrains Mono', monospace;
}

.event-row-title {
  flex: 1;
  font-size: 13px;
  font-weight: 600;
}

.event-alert {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 10.5px;
  color: var(--accent-yellow);
  background: rgba(255, 211, 42, 0.08);
  border: 1px solid rgba(255, 211, 42, 0.2);
  border-radius: 99px;
  padding: 2px 8px;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎｢・ｿ・ｽ繝ｻ・ｽ驛｢譎｢・ｽ・ｫ驛｢譏ｶ繝ｻ郢晢ｽ｣驛｢譎｢・ｿ・ｽ 髫ｨ貂可髫ｨ貂可 */
[data-tooltip] {
  position: relative;
}

[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-card);
  border: 1px solid var(--border-mid);
  color: var(--text-primary);
  font-size: 11px;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--transition);
  z-index: 1000;
}

[data-tooltip]:hover::after {
  opacity: 1;
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎｢・ｽ・ｭ驛｢・ｧ繝ｻ・ｰ髯ｷ繝ｻ・ｽ・ｺ髯ｷ迚呻ｽｸ蜻ｻ・ｿ・ｽ驛｢譎｢・ｿ・ｽ邵ｺ驢搾ｽｹ・ｧ繝ｻ・ｹ 髫ｨ貂可髫ｨ貂可 */
.log-box {
  background: #03040e;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 14px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  max-height: 280px;
  overflow-y: auto;
  line-height: 1.8;
}

.log-line {
  color: var(--text-secondary);
}

.log-line.success {
  color: var(--accent-green);
}

.log-line.warning {
  color: var(--accent-yellow);
}

.log-line.error {
  color: var(--accent-red);
}

/* 髫ｨ貂可髫ｨ貂可 髯具ｽｹ繝ｻ・ｺ髯具ｽｻ繝ｻ・ｽ繝ｻ莨√％繝ｻ・ｽ 髫ｨ貂可髫ｨ貂可 */
.divider {
  height: 1px;
  background: var(--border-subtle);
  margin: 20px 0;
}

/* 髫ｨ貂可髫ｨ貂可 鬩包ｽｨ繝ｻ・ｺ髴托ｽ･繝ｻ・ｶ髫ｲ・ｷ繝ｻ・ｽ 髫ｨ貂可髫ｨ貂可 */
.empty-state {
  text-align: center;
  padding: 48px 24px;
  color: var(--text-muted);
}

.empty-state .empty-icon {
  font-size: 40px;
  margin-bottom: 12px;
  opacity: 0.4;
}

.empty-state .empty-text {
  font-size: 13px;
}

/* 髫ｨ貂可髫ｨ貂可 Toast鬯ｨ・ｾ陞溘ｊ・｡繝ｻ髫ｨ貂可髫ｨ貂可 */
#toast-container {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.toast {
  background: var(--bg-card);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-md);
  padding: 12px 18px;
  font-size: 12.5px;
  min-width: 280px;
  max-width: 400px;
  display: flex;
  align-items: center;
  gap: 10px;
  animation: slideInRight 0.3s ease;
  box-shadow: var(--shadow-card);
}

.toast.success {
  border-color: rgba(0, 255, 157, 0.3);
}

.toast.success .toast-icon {
  color: var(--accent-green);
}

.toast.error {
  border-color: rgba(255, 71, 87, 0.3);
}

.toast.error .toast-icon {
  color: var(--accent-red);
}

.toast.warning {
  border-color: rgba(255, 211, 42, 0.3);
}

.toast.warning .toast-icon {
  color: var(--accent-yellow);
}

.toast.info {
  border-color: rgba(0, 212, 255, 0.3);
}

.toast.info .toast-icon {
  color: var(--accent-cyan);
}

.toast-icon {
  font-size: 16px;
}

.toast-message {
  flex: 1;
  color: var(--text-primary);
}

/* 髫ｨ貂可髫ｨ貂可 驛｢譎擾ｽ｣・ｹ繝ｻ・ｽ驛｢・ｧ繝ｻ・ｸ驛｢・ｧ繝ｻ・ｿ驛｢譎冗ｧ√・・ｼ陋ｹ・ｻ邵ｺ諷包ｽｹ譎｢・ｽ・ｳ驛｢譎｢・ｿ・ｽ・趣ｽｦ驛｢譎｢・ｿ・ｽ繝ｻ・｡繝ｻ・ｨ鬩穂ｼ夲ｽｽ・ｺ鬯ｮ・ｱ隶壹・・ｽ・｡繝ｻ・ｨ鬩穂ｼ夲ｽｽ・ｺ繝ｻ・ｽ繝ｻ・ｽ 髫ｨ貂可髫ｨ貂可 */
.page {
  display: none;
}

.page.active {
  display: block;
}

/* 髫ｨ貂可髫ｨ貂可 驍ｵ・ｺ隴擾ｽｴ繝ｻ・ｽ髣皮判縺假ｾ主｡・ｹ譎｢・ｽ・ｼ驛｢譎｢・ｿ・ｽ邵ｺ繝ｻ・ｹ譎｢・ｽ・ｪ驛｢譎｢・ｿ・ｽ邵ｺ繝ｻ髫ｨ貂可髫ｨ貂可 */
.text-cyan {
  color: var(--accent-cyan);
}

.text-green {
  color: var(--accent-green);
}

.text-red {
  color: var(--accent-red);
}

.text-yellow {
  color: var(--accent-yellow);
}

.text-muted {
  color: var(--text-muted);
}

.text-mono {
  font-family: 'JetBrains Mono', monospace;
}

.text-sm {
  font-size: 11.5px;
}

.text-xs {
  font-size: 10.5px;
}

.fw-600 {
  font-weight: 600;
}

.fw-700 {
  font-weight: 700;
}

.mt-8 {
  margin-top: 8px;
}

.mt-12 {
  margin-top: 12px;
}

.mt-16 {
  margin-top: 16px;
}

.mb-8 {
  margin-bottom: 8px;
}

.mb-12 {
  margin-bottom: 12px;
}

.mb-16 {
  margin-bottom: 16px;
}

.d-flex {
  display: flex;
}

.align-center {
  align-items: center;
}

.justify-between {
  justify-content: space-between;
}

.gap-8 {
  gap: 8px;
}

.gap-12 {
  gap: 12px;
}

.flex-1 {
  flex: 1;
}

.w-100 {
  width: 100%;
}

/* PC only / Mobile only 髯ｦ・ｨ驕会ｽｺ陋ｻ・ｶ陟包ｽ｡ */
.mobile-only {
  display: none;
}

/* 郢晢ｽ｢郢晁・縺・ｹ晢ｽｫ陝・ｽｾ陟｢繝ｻ*/

.sidebar-toggle {
  display: none;
  background: none;
  border: none;
  color: var(--text-primary);
  font-size: 20px;
  cursor: pointer;
  padding: 4px;
}

/* ============================================
   郢晢ｽｬ郢ｧ・ｹ郢晄亢ﾎｦ郢ｧ・ｷ郢晞摩・ｯ・ｾ陟｢繝ｻ(郢ｧ・ｿ郢晄じﾎ樒ｹ昴・繝ｨ: ~900px)
   ============================================ */
@media (max-width: 900px) {
  .sidebar {
    transform: translateX(-100%);
    box-shadow: none;
  }

  .sidebar.open {
    transform: translateX(0);
    box-shadow: 10px 0 30px rgba(0,0,0,0.5);
  }

  .sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    z-index: 99;
  }

  .main-content {
    margin-left: 0 !important;
    width: 100%;
  }

  .sidebar-toggle {
    display: block;
  }

  .form-row,
  .form-row-3 {
    grid-template-columns: 1fr;
  }

  .op-grid {
    grid-template-columns: 1fr 1fr;
  }

  .stats-grid {
    grid-template-columns: 1fr 1fr;
  }

  .content-area {
    padding: 16px;
  }

  /* section-header: 郢晄㈱縺｡郢晢ｽｳ邵ｺ遒∬◇邵ｺ繝ｻ・ｰ・ｴ陷ｷ蛹ｻ竊楢ｬ壼･・企恆譁撰ｼ */
  .section-header {
    flex-wrap: wrap;
    gap: 10px;
  }

  /* topbar 郢ｧ・ｿ郢ｧ・､郢晏現ﾎ晞坡・ｿ隰ｨ・ｴ */
  .topbar {
    padding: 0 14px;
    gap: 10px;
    width: 100%;
    overflow: hidden;
  }
  
  .topbar-title {
    font-size: 14px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .topbar-title {
    font-size: 13px;
  }

  .topbar-title span {
    display: none;
  }

  .bot-status {
    display: none;
  }

  /* 郢ｧ・､郢晏生ﾎｦ郢晞メ・｡繝ｻ 郢晢ｽ｢郢晁・縺・ｹ晢ｽｫ邵ｺ・ｧ驍ｵ・ｦ闕ｳ・ｦ邵ｺ・ｳ */
  .event-row {
    flex-wrap: wrap;
    gap: 8px;
  }

  .event-row-date {
    min-width: unset;
    font-size: 10px;
  }

  /* 陷ｿ繧・・髢繝ｻ縺堤ｹ晢ｽｩ郢晁ｼ斐・郢晢ｽｩ郢晏生ﾎ晁崕諤懶ｽｹ繝ｻ・ｪ・ｿ隰ｨ・ｴ */
  .participant-bar-row {
    grid-template-columns: 90px 1fr 60px;
  }

  /* 陷ｿ繧・・髢繝ｻ・ｩ・ｳ驍擾ｽｰ郢晏･繝｣郢敖郢晢ｽｼ */
  .p-detail-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 20px 16px;
  }

  /* 鬩幢ｽｨ驗ゑｽｲ郢ｧ・ｫ郢晢ｽｼ郢晏ｳｨ縺堤ｹ晢ｽｪ郢昴・繝ｩ */
  .dept-grid {
    grid-template-columns: 1fr;
  }

  /* 郢ｧ・ｿ郢ｧ・ｹ郢ｧ・ｯ郢晢ｽｬ郢ｧ・､郢ｧ・｢郢ｧ・ｦ郢昴・ 郢ｧ・ｵ郢ｧ・､郢晏ｳｨ繝ｰ郢晢ｽｼ郢ｧ蟶晄直髯ｦ・ｨ驕会ｽｺ邵ｲ竏昴・遶雁ｮ夲ｽ｡謔溘・郢ｧ鬆大ｴ帷ｸｺ繝ｻ*/
  .tasks-layout {
    grid-template-columns: 1fr !important;
    height: auto !important;
    overflow: visible !important;
  }

  .tasks-nav {
    display: none !important;
  }

  .tasks-content {
    padding: 12px 14px !important;
    overflow: visible;
  }

  .tasks-top-bar {
    flex-wrap: wrap;
    gap: 8px;
  }

  .tasks-page-title h2 {
    font-size: 1.2rem;
  }

  /* 郢ｧ・ｿ郢ｧ・ｹ郢ｧ・ｯ郢晄ｧｭ繝ｨ郢晢ｽｪ郢ｧ・ｯ郢ｧ・ｹ: 郢晢ｽ｢郢晁・縺・ｹ晢ｽｫ邵ｺ・ｧ邵ｺ・ｯ1陋ｻ繝ｻ*/
  .task-matrix {
    grid-template-columns: 1fr !important;
  }

  /* PC陝・ｉ逡題崕蜉ｱ・帝ｫｱ讚・ｽ｡・ｨ驕会ｽｺ / 郢晢ｽ｢郢晁・縺・ｹ晢ｽｫ陝・ｉ逡鷹囎竏ｫ・ｴ・ｰ郢ｧ螳夲ｽ｡・ｨ驕会ｽｺ */
  .pc-only {
    display: none !important;
  }

  .mobile-only {
    display: block !important;
  }

  /* 陷ｿ繧・・髢繝ｻ繝ｦ郢晢ｽｼ郢晄じﾎ・ 郢ｧ・ｹ郢晄ｧｭ繝ｻ邵ｺ・ｧ邵ｺ・ｯ陷ｷ讎顔√陋ｻ蜉ｱ繝ｻ邵ｺ・ｿ髯ｦ・ｨ驕会ｽｺ */
  #participants-table-body tr td:first-child {
    width: 100%;
  }

  /* 陷ｿ繧・・髢繝ｻ・ｩ・ｳ驍擾ｽｰ郢晢ｽ｢郢晢ｽｼ郢敖郢晢ｽｫ邵ｺ・ｮ驍ｨ・ｱ髫ｪ蛹ｻ縺堤ｹ晢ｽｪ郢昴・繝ｩ */
  .p-detail-stats {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  /* 髯ｦ謔溯劒髫ｪ蛟ｬ鮖ｸ邵ｺ・ｮ驍ｨ・ｱ髫ｪ蛹ｻ縺堤ｹ晢ｽｪ郢昴・繝ｩ */
  .p-logs-stats {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  /* p-log-card: 鬩･蟠趣ｽｦ竏晢ｽｺ・ｦ郢晁・繝｣郢ｧ・ｸ郢ｧ蛛ｵ縺｡郢ｧ・､郢晏現ﾎ晉ｸｺ・ｮ闕ｳ荵昶・ */
  .p-log-severity {
    position: static;
    display: inline-block;
    margin-bottom: 8px;
  }

  .p-log-badge {
    margin-bottom: 6px;
  }
}

/* ============================================
   郢晢ｽｬ郢ｧ・ｹ郢晄亢ﾎｦ郢ｧ・ｷ郢晞摩・ｯ・ｾ陟｢繝ｻ(郢ｧ・ｹ郢晄ｧｭ繝ｻ: ~640px)
   ============================================ */
@media (max-width: 640px) {
  html {
    font-size: 13px;
  }

  .content-area {
    padding: 12px;
  }

  /* 郢ｧ・ｫ郢晢ｽｼ郢昴・*/
  .card {
    padding: 16px;
  }

  .card-header {
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
    padding-bottom: 10px;
  }

  /* stats-grid: 2陋ｻ蜉ｱ縺冗ｹ晢ｽｼ郢昴・*/
  .stats-grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .stat-card {
    padding: 14px;
  }

  .stat-value {
    font-size: 22px;
  }

  /* op-grid: 2陋ｻ繝ｻ*/
  .op-grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .op-btn {
    padding: 16px 10px;
    gap: 8px;
  }

  .op-btn-icon {
    font-size: 22px;
  }

  .op-btn-label {
    font-size: 12px;
  }

  .op-btn-desc {
    display: none;
  }

  /* 郢ｧ・､郢晏生ﾎｦ郢晞メ・｡繝ｻ*/
  .event-row {
    padding: 10px 12px;
    gap: 6px;
    flex-wrap: wrap;
  }

  .event-row-date {
    font-size: 10px;
    min-width: 70px;
  }

  .event-row-title {
    font-size: 12px;
    width: 100%;
  }

  /* section-header: 驍ｵ・ｦ闕ｳ・ｦ邵ｺ・ｳ */
  .section-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .section-header > .d-flex {
    width: 100%;
    flex-wrap: wrap;
  }

  .section-title {
    font-size: 14px;
  }

  /* topbar */
  .topbar {
    height: 52px;
    padding: 0 12px;
  }

  /* 郢昴・繝ｻ郢晄じﾎ・ 隶難ｽｪ郢ｧ・ｹ郢ｧ・ｯ郢晢ｽｭ郢晢ｽｼ郢晢ｽｫ闖ｫ譎・ｽｨ・ｼ */
  .table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  table {
    min-width: 520px;
  }

  /* 陷ｿ繧・・髢繝ｻ繝ｦ郢晢ｽｼ郢晄じﾎ晉ｸｺ・ｯ陋ｻ蜉ｱ窶ｲ1邵ｺ・､邵ｺ・ｮ邵ｺ貅假ｽ［in-width闕ｳ蟠趣ｽｦ繝ｻ*/
  #page-participants table {
    min-width: unset;
    width: 100%;
  }

  /* 陷ｿ繧・・髢繝ｻ縺堤ｹ晢ｽｩ郢昴・*/
  .participant-bar-row {
    grid-template-columns: 70px 1fr 50px;
    gap: 6px;
  }

  .participant-bar-label {
    font-size: 10px;
  }

  /* detail-row: 驍ｵ・ｦ闕ｳ・ｦ邵ｺ・ｳ */
  .detail-row {
    flex-direction: column;
    gap: 4px;
  }

  .detail-label {
    min-width: unset;
  }

  /* p-detail */
  .p-detail-stats {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .p-action-grid {
    grid-template-columns: 1fr;
  }

  .p-logs-stats {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  /* 郢ｧ・ｿ郢晄じ繝ｰ郢晢ｽｼ */
  .tab-bar {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
    flex-wrap: nowrap;
  }

  .tab-btn {
    padding: 8px 12px;
    font-size: 11.5px;
  }

  /* 郢晏現繝ｻ郢ｧ・ｹ郢昴・*/
  #toast-container {
    bottom: 12px;
    right: 12px;
    left: 12px;
  }

  .toast {
    min-width: unset;
    max-width: 100%;
    font-size: 12px;
  }

  /* 郢ｧ・｢郢晉ｿｫ縺育ｹ晢ｽｳ郢ｧ・ｹ鬮｢・｢鬨ｾ・｣ */
  .announcement-list .announcement-card {
    padding: 12px;
  }

  /* 郢ｧ・ｿ郢ｧ・ｹ郢ｧ・ｯ郢晏｣ｹ繝ｻ郢ｧ・ｸ */
  .tasks-top-bar {
    flex-direction: column;
    align-items: flex-start;
  }

  .mobile-project-bar {
    padding: 8px 12px;
  }

  .mobile-task-tabs {
    gap: 4px;
  }

  .m-tab-btn {
    font-size: 10px;
    padding: 8px 4px;
  }

  .simple-task-card {
    padding: 12px;
  }
}

/* ============================================
   郢晢ｽｬ郢ｧ・ｹ郢晄亢ﾎｦ郢ｧ・ｷ郢晞摩・ｯ・ｾ陟｢繝ｻ(隶鯉ｽｵ陝・ｸ翫○郢晄ｧｭ繝ｻ: ~400px)
   ============================================ */
@media (max-width: 640px) {
  .stats-grid, .op-grid {
    grid-template-columns: 1fr;
  }
  
  .table-wrap table {
    min-width: 500px; /* 郢ｧ・ｹ郢晄ｧｭ繝ｻ邵ｺ・ｧ邵ｺ・ｯ郢昴・繝ｻ郢晄じﾎ晉ｹｧ蜻茨ｽｨ・ｪ郢ｧ・ｹ郢ｧ・ｯ郢晢ｽｭ郢晢ｽｼ郢晢ｽｫ邵ｺ霈披雷郢ｧ繝ｻ*/
  }

  .content-area {
    padding: 12px;
  }
}

/* ---- 陷ｿ繧・・髢繝ｻ縺堤ｹ晢ｽｩ郢昴・---- */
.participant-chart {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 8px;
}

.participant-bar-row {
  display: grid;
  grid-template-columns: 120px 1fr 80px;
  align-items: center;
  gap: 10px;
}

.participant-bar-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: right;
}

.participant-bar-wrap {
  height: 14px;
  background: var(--bg-panel);
  border-radius: 99px;
  overflow: hidden;
}

.participant-bar-fill {
  height: 100%;
  border-radius: 99px;
  transition: width 0.6s ease;
}

.participant-bar-count {
  font-size: 11px;
  color: var(--text-muted);
}

.dept-participant-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* .dept-participant-block styling moved or unused */

.dept-participant-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--bg-panel);
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
}

.dept-participant-members {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 0 4px;
}

.participant-chip {
  display: flex;
  flex-direction: column;
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  padding: 5px 10px;
  min-width: 100px;
}

.participant-chip-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-primary);
}

/* op-btn cyan */
.op-btn.cyan {
  border-color: rgba(0, 212, 255, 0.3);
}

.op-btn.cyan:hover {
  background: rgba(0, 212, 255, 0.12);
  border-color: rgba(0, 212, 255, 0.6);
}

.op-btn.cyan .op-btn-roman {
  color: var(--accent-cyan);
}

/* op-btn yellow */
.op-btn.yellow {
  border-color: rgba(255, 204, 0, 0.3);
}

.op-btn.yellow:hover {
  background: rgba(255, 204, 0, 0.12);
  border-color: rgba(255, 204, 0, 0.6);
}

.op-btn.yellow .op-btn-roman {
  color: var(--accent-yellow);
}

/* 驍擾ｽｹ闔我ｹ昴″郢晢ｽｼ郢昴・(Profile Card View) */
.profile-card-view {
  padding: 8px 4px;
}

.p-header {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 24px;
}

.p-avatar {
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, var(--accent-orange), #ff6b6b);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 800;
  color: white;
  box-shadow: 0 4px 12px rgba(255, 107, 107, 0.3);
}

.p-info .p-name {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.p-info .p-username {
  font-size: 13px;
  color: var(--text-secondary);
  font-weight: 400;
}

.p-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}

.p-item {
  background: var(--bg-panel);
  padding: 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle);
}

.p-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}

.p-value {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
}

.p-section {
  margin-bottom: 20px;
}

.p-bio {
  background: var(--bg-panel);
  padding: 16px;
  border-radius: var(--radius-md);
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-primary);
  border-left: 4px solid var(--accent-orange);
  white-space: pre-wrap;
}

.p-extra-depts {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.p-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--accent-cyan);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  margin-top: 4px;
}

.p-link:hover {
  text-decoration: underline;
}

/* 郢晢ｽ｡郢晢ｽｳ郢晁・繝ｻ郢晄ｺ倥Ν郢晢ｽｪ郢ｧ・ｹ郢昴・*/
.member-list-mini {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.member-item-mini {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--bg-card);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle);
  cursor: pointer;
  transition: all 0.2s;
}

.member-item-mini:hover {
  border-color: var(--accent-orange);
  transform: translateX(4px);
  background: var(--bg-card-hover);
}

.m-info .m-name {
  font-weight: 700;
  font-size: 15px;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.m-role {
  display: flex;
  gap: 4px;
}

.friends-selector,
.extra-depts-selector {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 44px;
  padding: 12px;
  background: var(--bg-panel);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
}

.friend-chip,
.dept-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: var(--bg-card);
  border: 1px solid var(--border-mid);
  border-radius: 99px;
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s;
  user-select: none;
}

.friend-chip input,
.dept-chip input {
  display: none;
}

.friend-chip:has(input:checked),
.dept-chip:has(input:checked) {
  background: rgba(92, 124, 250, 0.15);
  border-color: var(--accent-cyan);
  color: var(--accent-cyan);
}

.friend-tag {
  display: inline-block;
  padding: 4px 10px;
  background: var(--bg-panel);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  font-size: 12px;
  color: var(--text-primary);
  margin-right: 6px;
  margin-bottom: 6px;
}

.p-friends-list {
  display: flex;
  flex-wrap: wrap;
  margin-top: 8px;
}

/* ============================================
   驕ｨ・ｶ隶鯉ｽｵ邵ｺ・ｮ郢ｧ・ｿ郢ｧ・ｹ郢ｧ・ｯ驍ゑｽ｡騾・・・ｼ螢ｽ・ｴ遉ｼ・ｷ・ｴ邵ｺ・ｨ騾ｶ・ｴ隲｢繝ｻ(Clean & Simple)
   ============================================ */

.tasks-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    height: calc(100vh - 60px);
    background: #0f1014;
    overflow: hidden;
}

/* 陝ｾ・ｦ繝ｻ螢ｹ繝ｻ郢晢ｽｭ郢ｧ・ｸ郢ｧ・ｧ郢ｧ・ｯ郢晏現繝ｻ郢晢ｽ｡郢昜ｹ斟礼ｹ晢ｽｼ */
.tasks-nav {
    background: #16171d;
    border-right: 1px solid rgba(255, 255, 255, 0.05);
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.nav-title {
    font-size: 11px;
    font-weight: 800;
    color: var(--accent-cyan);
    letter-spacing: 2px;
    margin-bottom: 12px;
}

.project-list-clean {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.project-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.2s;
    font-size: 13px;
    color: var(--text-secondary);
}

.project-link:hover {
    background: rgba(255, 255, 255, 0.03);
    color: #fff;
}

.project-link.active {
    background: rgba(0, 212, 255, 0.1);
    color: var(--accent-cyan);
    font-weight: 600;
}

.project-color-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

/* 陷ｿ・ｳ繝ｻ螢ｹﾎ鍋ｹｧ・､郢晢ｽｳ郢ｧ・ｳ郢晢ｽｳ郢昴・ﾎｦ郢昴・*/
.tasks-content {
    display: flex;
    flex-direction: column;
    padding: 24px 32px;
    overflow-y: auto;
    gap: 24px;
}

.tasks-top-bar {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

.tasks-page-title h2 {
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 4px;
}

/* 郢ｧ・ｿ郢ｧ・ｹ郢ｧ・ｯ郢ｧ・ｰ郢晢ｽｪ郢昴・繝ｩ繝ｻ蛹ｻ縺咲ｹ晢ｽｩ郢晢｣ｰ陟厄ｽ｢陟第得・ｼ繝ｻ*/
.task-matrix {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    align-items: start;
}

.matrix-col {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.matrix-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 4px;
    border-bottom: 2px solid rgba(255, 255, 255, 0.05);
    margin-bottom: 8px;
}

.matrix-title {
    font-size: 12px;
    font-weight: 700;
    color: var(--text-muted);
}

/* 郢ｧ・ｷ郢晢ｽｳ郢晏干ﾎ晉ｹｧ・ｿ郢ｧ・ｹ郢ｧ・ｯ郢ｧ・ｫ郢晢ｽｼ郢昴・*/
.simple-task-card {
    background: #1c1d24;
    border-radius: 12px;
    padding: 16px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    cursor: pointer;
    transition: transform 0.2s, border-color 0.2s;
}

.simple-task-card:hover {
    border-color: var(--accent-cyan);
    transform: translateY(-2px);
}

.st-priority {
    font-size: 10px;
    font-weight: 800;
    color: var(--text-muted);
    text-align: right;
}

.card-footer-advanced {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
    border-top: 1px solid rgba(255, 255, 255, 0.03);
}

.card-assignee-avatar {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.1);
    object-fit: cover;
}

/* 郢ｧ・ｿ郢ｧ・ｹ郢ｧ・ｯ郢晏｣ｹ繝ｻ郢ｧ・ｸ邵ｺ・ｮ郢晢ｽ｢郢晁・縺・ｹ晢ｽｫ隴崢鬩包ｽｩ陋ｹ蜴・ｽｼ繝ｻain.css邵ｺ・ｮ@media邵ｺ・ｨ鬨ｾ・｣隰ｳ・ｺ繝ｻ繝ｻ*/

/* 郢晁ｼ斐°郢晢ｽｼ郢晢｣ｰ & 郢晢ｽ｢郢晢ｽｼ郢敖郢晢ｽｫ髫ｱ・ｿ隰ｨ・ｴ */
.form-glass {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    padding: 12px;
    color: #fff;
    width: 100%;
}

/* 郢晁・繝｣郢ｧ・ｸ陷讎奇ｽｮ螟ゑｽｾ・ｩ */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
}

.badge-ghost { background: var(--bg-panel); color: var(--text-muted); border: 1px solid var(--border-subtle); }
.badge-cyan { background: rgba(0, 212, 255, 0.12); color: var(--accent-cyan); border: 1px solid rgba(0, 212, 255, 0.25); }
.badge-purple { background: rgba(190, 75, 219, 0.12); color: var(--accent-purple); border: 1px solid rgba(190, 75, 219, 0.25); }
.badge-orange { background: rgba(255, 146, 67, 0.12); color: var(--accent-orange); border: 1px solid rgba(255, 146, 67, 0.25); }
.badge-red { background: rgba(255, 71, 87, 0.12); color: var(--accent-red); border: 1px solid rgba(255, 71, 87, 0.25); }
.badge-green { background: rgba(0, 255, 157, 0.12); color: var(--accent-green); border: 1px solid rgba(0, 255, 157, 0.25); }

/* 陷ｿ繧・・髢繝ｻ縺・ｹ晁・縺｡郢晢ｽｼ */
.participant-avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-sm);
  object-fit: cover;
  border: 1.5px solid rgba(255, 255, 255, 0.1);
  background: var(--bg-card);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  flex-shrink: 0;
}

.participant-avatar-none {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-sm);
  background: var(--bg-panel);
  border: 1.5px solid rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  flex-shrink: 0;
}

.participant-avatar-none .material-symbols-outlined {
  font-size: 18px;
}

/* ============================================
   陷ｿ繧・・髢繝ｻ・ｩ・ｳ驍擾ｽｰ郢晢ｽ｢郢晢ｽｼ郢敖郢晢ｽｫ (Premium Design)
   ============================================ */
.p-detail-card {
  padding: 8px;
  background: var(--bg-card);
  border-radius: var(--radius-lg);
}

.p-detail-header {
  position: relative;
  padding: 32px 24px;
  background: linear-gradient(135deg, rgba(92, 124, 250, 0.08) 0%, rgba(0, 212, 255, 0.05) 100%);
  border-radius: var(--radius-md);
  margin-bottom: 24px;
  border: 1px solid rgba(255, 255, 255, 0.03);
  display: flex;
  align-items: center;
  gap: 24px;
  overflow: hidden;
}

.p-detail-header::before {
  content: "";
  position: absolute;
  top: -50px;
  right: -50px;
  width: 150px;
  height: 150px;
  background: radial-gradient(circle, rgba(92, 124, 250, 0.1) 0%, transparent 70%);
  border-radius: 50%;
}

.p-detail-avatar {
  width: 88px;
  height: 88px;
  border-radius: 18px;
  border: 3px solid var(--bg-card);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
  object-fit: cover;
  z-index: 1;
}

.p-detail-avatar-none {
  width: 88px;
  height: 88px;
  border-radius: 18px;
  background: var(--bg-panel);
  border: 3px solid var(--bg-card);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
  z-index: 1;
}

.p-detail-name-area {
  z-index: 1;
}

.p-detail-name {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}

.p-detail-id {
  font-family: 'Roboto Mono', monospace;
  font-size: 13px;
  color: var(--text-muted);
  opacity: 0.8;
  display: flex;
  align-items: center;
  gap: 6px;
}

.p-detail-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 24px;
}

.p-stat-box {
  padding: 16px;
  background: var(--bg-panel);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  transition: border-color 0.2s;
}

.p-stat-box:hover {
  border-color: var(--border-mid);
}

.p-stat-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 8px;
  letter-spacing: 0.05em;
}

.p-stat-value {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
}

.p-detail-section {
  padding: 0 4px;
}

.p-detail-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.p-detail-label span {
  font-size: 18px;
  color: var(--accent-cyan);
}

.p-action-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 32px;
}

/* ============================================
   髯ｦ謔溯劒髫ｪ蛟ｬ鮖ｸ (Strongest UI)
   ============================================ */
.p-logs-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.p-logs-stat-item {
  padding: 12px;
  background: var(--bg-panel);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  text-align: center;
}

.p-logs-stat-item .label {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-bottom: 4px;
}

.p-logs-stat-item .val {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
}

.p-logs-stat-item.warn { border-color: rgba(255, 152, 0, 0.3); }
.p-logs-stat-item.warn .val { color: #ff9800; }
.p-logs-stat-item.crit { border-color: rgba(244, 67, 54, 0.3); }
.p-logs-stat-item.crit .val { color: #f44336; }
.p-logs-stat-item.good { border-color: rgba(76, 175, 80, 0.3); }
.p-logs-stat-item.good .val { color: #4caf50; }

.p-logs-form {
  padding: 16px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
}

.p-log-card {
  position: relative;
  padding: 16px;
  background: var(--bg-panel);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  margin-bottom: 12px;
  border-left: 4px solid #888;
  transition: transform 0.2s, box-shadow 0.2s;
}

.p-log-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.p-log-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 99px;
  font-size: 11px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 12px;
}

.p-log-badge span { font-size: 14px; }

.p-log-severity {
  position: absolute;
  top: 16px;
  right: 16px;
  font-size: 10px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 4px;
  text-transform: uppercase;
}

.p-severity-low { background: rgba(136, 136, 136, 0.1); color: #888; }
.p-severity-normal { background: rgba(92, 124, 250, 0.1); color: var(--accent-cyan); }
.p-severity-high { background: rgba(244, 67, 54, 0.1); color: #f44336; }

.p-log-content {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-primary);
  margin-bottom: 16px;
  white-space: pre-wrap;
}

.p-log-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.p-log-author-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
}

.p-log-author-avatar-none {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--bg-card);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
}

.p-log-author-avatar-none span { font-size: 14px; }

.p-logs-filters {
  display: flex;
  gap: 8px;
}

.btn-filter {
  padding: 6px 16px;
  background: var(--bg-panel);
  border: 1px solid var(--border-subtle);
  border-radius: 99px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  transition: all 0.2s;
}

.btn-filter:hover {
  background: var(--bg-card);
  color: var(--text-primary);
}

.btn-filter.active {
  background: var(--accent-cyan);
  border-color: var(--accent-cyan);
  color: #fff;
  box-shadow: 0 4px 12px rgba(0, 212, 255, 0.3);
}
/* Full-Width Page Support */
.content-area.page-full-width {
  padding: 0 !important;
  max-width: none !important;
}

.tasks-layout { max-width: 100vw !important; }
@media (max-width: 768px) {
  .content-area.page-full-width { overflow-x: hidden; }
  .kanban-scroll-wrap { padding: 12px !important; }
}

/* Mobile Task UI Refinement */
.mobile-task-tabs {
  display: none;
  background: #16171d;
  padding: 8px;
  position: sticky;
  top: 0;
  z-index: 10;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}
.m-tab-btn {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-size: 11px;
  font-weight: 700;
  padding: 10px 4px;
  border-radius: 8px;
  text-align: center;
}
.m-tab-btn.active {
  background: rgba(0, 212, 255, 0.1);
  color: var(--accent-cyan);
}
.mobile-project-bar {
  display: none;
  padding: 12px 16px;
  background: #0f1014;
  overflow-x: auto;
  white-space: nowrap;
  gap: 8px;
}
@media (max-width: 900px) {
  .mobile-task-tabs { display: flex; }
  .mobile-project-bar { display: flex; }
  .matrix-col { display: none; }
  .matrix-col.active-mobile { display: flex; flex-direction: column; width: 100%; }
  .task-detail-mobile-stack { grid-template-columns: 1fr !important; }
  .task-side-pane { margin-top: 20px; }
}

/* ============================================
   邵ｺ鬘碑｡咲ｹｧ蟲ｨ笳矩勗蠕後・郢ｧ・｢郢晉ｿｫ縺育ｹ晢ｽｳ郢ｧ・ｹ髯ｦ蠕後・郢晢ｽｬ郢ｧ・ｹ郢晄亢ﾎｦ郢ｧ・ｷ郢昴・   ============================================ */
.announcement-row {
  word-break: break-word;
}

@media (max-width: 640px) {
  .announcement-row,
  .announcement-row-full {
    padding: 10px 12px !important;
  }

  .announcement-row .d-flex,
  .announcement-row-full .d-flex {
    flex-wrap: wrap;
    gap: 6px;
  }

  /* 郢ｧ・､郢晏生ﾎｦ郢晏現ﾎ懃ｹｧ・ｹ郢晏現繝ｻ郢晁ｼ斐≦郢晢ｽｫ郢ｧ・ｿ郢晢ｽｼ+郢晄㈱縺｡郢晢ｽｳ */
  #page-event-list .section-header > .d-flex {
    width: 100%;
    flex-wrap: wrap;
  }

  #event-filter {
    width: 100% !important;
    flex: 1;
  }

  /* 陷ｿ繧・・髢繝ｻ・､諛・ｽｴ・｢ */
  #participant-search {
    width: 100% !important;
  }

  /* 邵ｺ鬘碑｡咲ｹｧ蟲ｨ笳玖ｬ壽・・ｨ・ｿ郢晄㈱縺｡郢晢ｽｳ */
  #btn-create-announcement-list {
    width: 100%;
  }
}

/* =========================================
   TeruSleep HR Settings (Modern UI)
   ========================================= */
.hr-container {
  display: flex;
  flex-direction: column;
  gap: 20px;
  animation: fadeIn 0.5s ease;
}

.hq-card {
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, var(--bg-card) 0%, rgba(255, 255, 255, 0.02) 100%);
  overflow: hidden;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.hq-card:hover {
  border-color: rgba(0, 212, 255, 0.3);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

.hq-card .card-header {
  padding: 16px 20px;
  background: rgba(255, 255, 255, 0.03);
  border-bottom: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.hq-card .card-title {
  font-family: 'Outfit', sans-serif;
  font-size: 15px;
  letter-spacing: 0.02em;
  color: var(--text-primary);
}

.hq-card .card-title .icon {
  color: var(--accent-cyan);
  filter: drop-shadow(0 0 5px rgba(0, 212, 255, 0.4));
}

.dept-list {
  background: rgba(0, 0, 0, 0.15);
  padding: 12px !important;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dept-item {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: all 0.25s ease;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.dept-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 3px;
  background: var(--accent-cyan);
  opacity: 0;
  transition: opacity 0.2s;
}

.dept-item:hover {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(0, 212, 255, 0.4);
  transform: translateX(4px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.dept-item:hover::before {
  opacity: 1;
}

.dept-item-left {
  display: flex;
  align-items: center;
  gap: 14px;
}

.dept-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.dept-name {
  font-weight: 700;
  font-size: 13.5px;
  color: var(--text-primary);
}

.dept-desc {
  font-size: 11px;
  color: var(--text-muted);
  max-width: 400px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dept-item-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.user-count-chip {
  background: rgba(0, 212, 255, 0.1);
  color: var(--accent-cyan);
  padding: 4px 10px;
  border-radius: 99px;
  font-size: 11px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 6px;
  border: 1px solid rgba(0, 212, 255, 0.2);
}

.user-count-chip .material-symbols-outlined {
  font-size: 14px;
}

.dept-item .arrow {
  font-size: 18px;
  color: var(--text-muted);
  opacity: 0;
  transition: all 0.2s;
  transform: translateX(-5px);
}

.dept-item:hover .arrow {
  opacity: 1;
  transform: translateX(0);
  color: var(--accent-cyan);
}

.hq-drag-handle, .dept-drag-handle {
  opacity: 0.3;
  transition: opacity 0.2s;
  cursor: grab !important;
}

.hq-drag-handle:hover, .dept-drag-handle:hover {
  opacity: 1;
}
/* =========================================
   TeruSleep HR Settings (Sophisticated Premium UI)
   ========================================= */
.hr-container {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  gap: 24px;
}

.hq-card {
  background: var(--bg-panel);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  overflow: hidden;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.hq-card:hover {
  border-color: rgba(255, 255, 255, 0.15);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.hq-card .card-header {
  padding: 20px 24px;
  background: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.hq-card .card-title {
  font-family: 'Outfit', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.02em;
  display: flex;
  align-items: center;
  gap: 12px;
}

.hq-card .card-title .icon {
  font-size: 20px;
  color: var(--accent-cyan);
}

.dept-list {
  padding: 16px !important;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dept-item {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 8px;
  padding: 14px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background 0.2s ease, border-color 0.2s ease;
  cursor: pointer;
}

.dept-item:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.15);
}

.dept-name {
  font-weight: 700;
  font-size: 15px;
  color: #fff;
  letter-spacing: 0.02em;
}

.dept-desc {
  font-size: 11.5px;
  color: var(--text-muted);
  font-weight: 400;
  margin-top: 2px;
}

.user-count-chip {
  background: rgba(0, 0, 0, 0.2);
  color: var(--text-muted);
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.dept-item:hover .user-count-chip {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.1);
}

.hq-drag-handle, .dept-drag-handle {
  opacity: 0.2;
  transition: opacity 0.2s;
  cursor: grab;
}

.hq-card:hover .hq-drag-handle,
.dept-item:hover .dept-drag-handle {
  opacity: 0.6;
}

/* Member Avatars inside dept-item */
.dept-member-avatar-list {
  display: flex;
  margin-top: 8px;
}

.dept-member-avatarSmall {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1px solid var(--bg-panel);
  margin-right: -4px;
  background: var(--bg-hover);
  object-fit: cover;
}


/* Department Members List inside card */
.dept-member-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-height: 200px;
  overflow-y: auto;
  padding-right: 4px;
}

.dept-member-item {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 12px;
  transition: all 0.2s ease;
}

.dept-member-item:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.1);
}

.dept-member-avatar {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  object-fit: cover;
}

.dept-member-name {
  font-weight: 500;
  color: #eee;
}

/* ====== Member Panel Cards (Practical UI) ====== */

/* ====== Minimalist Executive Member Cards (Apple/Linear Style) ====== */
.hq-group {
  margin-bottom: 50px;
}

.hq-title-panel {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 24px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.unit-panel-section {
  margin-bottom: 36px;
}

.unit-panel-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}

.unit-panel-header .unit-name {
  font-size: 15px;
  font-weight: 700;
  color: #fff;
}

.unit-panel-header .unit-count {
  font-size: 11px;
  color: var(--text-muted);
  background: rgba(255, 255, 255, 0.03);
  padding: 1px 8px;
  border-radius: 4px;
}

.member-panel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 12px;
}

.member-exec-card {
  background: #14151a;
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 12px;
  transition: all 0.2s ease;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.member-exec-card:hover {
  background: #1c1d24;
  border-color: rgba(255, 255, 255, 0.1);
}

.exec-card-inner {
  padding: 16px;
  display: flex;
  align-items: center;
  gap: 16px;
}

.exec-avatar-area {
  position: relative;
  width: 52px;
  height: 52px;
  flex-shrink: 0;
}

.exec-avatar {
  width: 100%;
  height: 100%;
  border-radius: 10px;
  object-fit: cover;
  border: 1px solid rgba(255, 255, 255, 0.03);
}

.exec-avatar-fallback {
  width: 100%;
  height: 100%;
  border-radius: 10px;
  background: #23242b;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 700;
  color: #444;
}

.exec-owner-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  background: #ff922b;
  color: #000;
  width: 18px;
  height: 18px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  border: 1px solid #14151a;
}

.exec-info {
  flex: 1;
  min-width: 0;
}

.exec-name-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 2px;
}

.exec-name {
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ============================================
   繝ｦ繝ｼ繝・ぅ繝ｪ繝・ぅ繧ｯ繝ｩ繧ｹ (Reports & General)
   ============================================ */
.d-flex { display: flex; }
.flex-column { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.align-items-center { align-items: center; }
.justify-content-between { justify-content: space-between; }
.justify-content-end { justify-content: flex-end; }
.gap-4 { gap: 4px; }
.gap-8 { gap: 8px; }
.gap-16 { gap: 16px; }

.mb-8 { margin-bottom: 8px; }
.mb-12 { margin-bottom: 12px; }
.mb-16 { margin-bottom: 16px; }
.mb-20 { margin-bottom: 20px; }

.p-12 { padding: 12px; }
.w-100 { width: 100%; }

.section-divider {
  height: 1px;
  background: var(--border-mid);
  margin: 20px 0;
}

.card-subtle {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
}

.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--bg-panel);
  padding: 4px 10px;
  border-radius: 99px;
  font-size: 12px;
  cursor: pointer;
  transition: var(--transition);
  border: 1px solid var(--border-subtle);
}

.filter-chip:hover, .filter-chip.active {
  background: rgba(0, 212, 255, 0.1);
  border-color: var(--accent-cyan);
  color: var(--accent-cyan);
}

.text-red { color: var(--accent-red); }
.text-accent { color: var(--accent-cyan); }

.step-num {
  width: 20px;
  height: 20px;
  background: var(--accent-cyan);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
}

/* ============================================
   蝣ｱ蜻頑･ｭ蜍吶・繝ｼ繧ｸ逕ｨ繧ｹ繧ｿ繧､繝ｫ
   ============================================ */
.reports-container {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.reports-tabs {
  display: flex;
  gap: 10px;
  border-bottom: 1px solid var(--border-mid);
  padding-bottom: 10px;
}

.report-tab {
  padding: 8px 16px;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--text-secondary);
  border: none;
  cursor: pointer;
  font-weight: 600;
  transition: var(--transition);
}

.report-tab:hover {
  background: var(--bg-card-hover);
  color: var(--text-primary);
}

.report-tab.active {
  background: var(--accent-cyan);
  color: #fff;
}

.reports-list-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
}

.report-card {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 16px;
  transition: var(--transition);
  cursor: pointer;
  position: relative;
  overflow: hidden;
}

.report-card:hover {
  transform: translateY(-4px);
  border-color: var(--accent-cyan);
  background: var(--bg-card-hover);
}

.report-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 12px;
}

.report-status-badge {
  padding: 4px 10px;
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
}

.status-pending { background: rgba(252, 196, 25, 0.15); color: var(--accent-yellow); }
.status-approved { background: rgba(64, 192, 87, 0.15); color: var(--accent-green); }
.status-remanded { background: rgba(250, 82, 82, 0.15); color: var(--accent-red); }
.status-completed { background: rgba(92, 124, 250, 0.15); color: var(--accent-cyan); }

.report-title {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 4px;
}

.report-info {
  font-size: 13px;
  color: var(--text-secondary);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* ============================================================
   申請プロセスバー（カード表示用）proc-* クラス
   ============================================================ */
.proc-bar-wrap {
  display: flex;
  align-items: flex-start;
  gap: 0;
  overflow-x: auto;
  padding: 10px 0 4px;
  margin-top: 12px;
  border-top: 1px dashed var(--border-mid);
  scrollbar-width: none;
}
.proc-bar-wrap::-webkit-scrollbar { display: none; }

.proc-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  flex-shrink: 0;
  min-width: 52px;
}

.proc-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  border: 2px solid var(--border-mid);
  background: var(--bg-base);
  color: var(--text-muted);
  transition: all 0.2s;
  flex-shrink: 0;
  line-height: 1;
}
.proc-dot.proc-done { background: var(--accent-green); border-color: var(--accent-green); color: #fff; }
.proc-dot.proc-active { background: var(--accent-yellow); border-color: var(--accent-yellow); color: #000; box-shadow: 0 0 0 3px rgba(252,196,25,0.25); }
.proc-dot.proc-remanded { background: var(--accent-red); border-color: var(--accent-red); color: #fff; }
.proc-dot.proc-wait { background: var(--bg-panel); border-color: var(--border-mid); color: var(--text-muted); }

.proc-label {
  font-size: 9px;
  color: var(--text-muted);
  text-align: center;
  max-width: 52px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.3;
}

.proc-line {
  flex: 1;
  min-width: 12px;
  height: 2px;
  background: var(--border-mid);
  margin-top: 13px;
  flex-shrink: 1;
}
.proc-line.proc-line-done { background: var(--accent-green); }

/* 新着カードハイライト */
.report-card-new {
  border-color: var(--accent-cyan) !important;
  box-shadow: 0 0 0 2px rgba(0,212,255,0.15), var(--shadow-card) !important;
}
.report-card-new::after {
  content: '新着';
  position: absolute;
  top: 10px;
  right: 10px;
  font-size: 9px;
  font-weight: 800;
  color: var(--accent-cyan);
  background: rgba(0,212,255,0.12);
  border: 1px solid rgba(0,212,255,0.35);
  border-radius: 4px;
  padding: 2px 6px;
  letter-spacing: 0.05em;
  pointer-events: none;
}

.report-process-visual {
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px dashed var(--border-mid);
  display: flex;
  align-items: center;
  gap: 8px;
  overflow-x: auto;
}

.process-step-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--bg-base);
  border: 2px solid var(--text-muted);
}

.process-step-dot.active { border-color: var(--accent-yellow); background: var(--accent-yellow); }
.process-step-dot.completed { border-color: var(--accent-green); background: var(--accent-green); }

/* 繝｢繝ｼ繝繝ｫ逕ｨ */
.process-timeline {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin: 20px 0;
  padding: 16px;
  background: rgba(0, 0, 0, 0.2);
  border-radius: var(--radius-lg);
}

.timeline-item {
  display: flex;
  gap: 16px;
  position: relative;
}

.timeline-item:not(:last-child)::after {
  content: '';
  position: absolute;
  left: 11px;
  top: 24px;
  bottom: -16px;
  width: 2px;
  background: var(--border-mid);
}

.timeline-icon {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--bg-panel);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

.timeline-icon .material-symbols-outlined { font-size: 16px; }

.timeline-content {
  flex: 1;
}

.timeline-title {
  font-size: 14px;
  font-weight: 600;
}

.timeline-status {
  font-size: 12px;
  color: var(--text-secondary);
}

.timeline-comment {
  margin-top: 4px;
  padding: 8px;
  background: rgba(250, 82, 82, 0.1);
  border-left: 3px solid var(--accent-red);
  font-size: 13px;
  border-radius: 4px;
}

/* 繧ｹ繝槭・蟇ｾ蠢・*/
@media (max-width: 768px) {
  .reports-list-grid {
    grid-template-columns: 1fr;
  }
}

.exec-badge {
  font-size: 9px;
  font-weight: 800;
  color: var(--accent-cyan);
  background: rgba(92, 124, 250, 0.1);
  padding: 0 5px;
  border-radius: 3px;
  border: 1px solid rgba(92, 124, 250, 0.2);
}

.exec-username {
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 8px;
}

.exec-org {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
}

.exec-hq {
  color: var(--text-muted);
  white-space: nowrap;
}

.exec-dept {
  color: var(--accent-cyan);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* 繝ｬ繧､繧｢繧ｦ繝井ｿｮ豁｣: 蜿ｳ蛛ｴ縺ｮ菴咏區髦ｲ豁｢ */
.layout {
  overflow-x: hidden;
  max-width: 100%;
}

.main-content {
  overflow-x: hidden;
}

/* 繝懊ち繝ｳ縺ｮ蠖｢迥ｶ菫ｮ豁｣: 荳ｸ縺吶℃繧定ｧ｣豸・*/
.btn-primary, .btn-success, .btn-purple {
  border-radius: 6px !important;
}

/* 逕ｳ隲区･ｭ蜍吶・繝ｼ繧ｸ縺ｮ繧ｰ繝ｪ繝・ラ隱ｿ謨ｴ */
.reports-list-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
  width: 100%;
}

/* セレクトボックスの視認性向上 */
select.form-control {
  cursor: pointer !important;
  background-image: url('data:image/svg+xml,%3Csvg xmlns=\'http://www.w3.org/2000/svg\' width=\'12\' height=\'12\' viewBox=\'0 0 24 24\' fill=\'none\' stroke=\'%23ffffff\' stroke-width=\'2\' stroke-linecap=\'round\' stroke-linejoin=\'round\'%3E%3Cpolyline points=\'6 9 12 15 18 9\'%3E%3C/polyline%3E%3C/svg%3E') !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  appearance: none !important;
  padding-right: 36px !important;
  background-color: var(--bg-input) !important;
  color: var(--text-primary) !important;
}

select.form-control option {
  background: #1a1b1e !important;
  color: #fff !important;
  padding: 8px !important;
}

/* タブバッジ（件数・縦中央揃え） */
.report-tab {
  position: relative;
}
.tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 6px;
  background: var(--accent-red);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  min-width: 16px;
  height: 16px;
  border-radius: 8px;
  padding: 0 4px;
  line-height: 1;
  vertical-align: middle;
}

/* ============================================
   申請業務 フォルダUI
   ============================================ */
.report-folder-group {
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 12px 16px 10px;
}
.report-folder-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 800;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 10px;
}
.report-folder-group:first-child .report-folder-label {
  color: var(--accent-cyan);
}
.report-folder-group:nth-child(2) .report-folder-label {
  color: var(--accent-orange);
}
.reports-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  border-bottom: none;
  padding-bottom: 0;
}

/* ============================================
   申請業務 プロセスバー
   ============================================ */
.report-process-bar {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed var(--border-mid);
}
.proc-bar-wrap {
  display: flex;
  align-items: flex-start;
  gap: 0;
}
.proc-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
.proc-dot {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  border: 2px solid var(--border-mid);
  background: var(--bg-base);
  color: var(--text-muted);
  transition: all 0.3s;
  flex-shrink: 0;
}
.proc-dot.proc-done {
  background: var(--accent-green);
  border-color: var(--accent-green);
  color: #fff;
  box-shadow: 0 0 10px rgba(64,192,87,0.4);
}
.proc-dot.proc-active {
  background: var(--accent-yellow);
  border-color: var(--accent-yellow);
  color: #000;
  box-shadow: 0 0 12px rgba(252,196,25,0.5);
  animation: pulseDot 1.4s ease-in-out infinite;
}
.proc-dot.proc-remanded {
  background: var(--accent-red);
  border-color: var(--accent-red);
  color: #fff;
  box-shadow: 0 0 12px rgba(250,82,82,0.5);
}
.proc-dot.proc-wait {
  opacity: 0.4;
}
@keyframes pulseDot {
  0%, 100% { box-shadow: 0 0 12px rgba(252,196,25,0.5); }
  50%       { box-shadow: 0 0 20px rgba(252,196,25,0.9); }
}
.proc-label {
  font-size: 10px;
  color: var(--text-muted);
  text-align: center;
  max-width: 60px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2;
}
.proc-line {
  flex: 1;
  height: 2px;
  background: var(--border-mid);
  margin-top: 11px; /* ドットの中心に合わせる */
  align-self: flex-start;
  min-width: 12px;
  transition: background 0.3s;
}
.proc-line.proc-line-done {
  background: var(--accent-green);
  box-shadow: 0 0 6px rgba(64,192,87,0.3);
}

/* timeline 差し戻し状態 */
.timeline-item.remanded .timeline-icon {
  background: rgba(250,82,82,0.15);
  color: var(--accent-red);
}
.timeline-item.completed .timeline-icon {
  background: rgba(64,192,87,0.15);
  color: var(--accent-green);
}
.timeline-item.active .timeline-icon {
  background: rgba(252,196,25,0.15);
  color: var(--accent-yellow);
}

/* ============================================
   プロセスバー GOAL バッジ
   ============================================ */
.proc-goal-badge {
  font-size: 8px;
  font-weight: 900;
  color: var(--accent-cyan);
  background: rgba(0,212,255,0.12);
  border: 1px solid rgba(0,212,255,0.3);
  border-radius: 4px;
  padding: 1px 4px;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

/* ============================================================
   フォルダ内タブ: PC時は横並び、モバイル時は縦並び
   ============================================================ */
@media (min-width: 900px) {
  .reports-tabs {
    flex-direction: row !important;
    flex-wrap: wrap;
  }
  .reports-tabs .report-tab {
    flex: 1;
    text-align: center;
    white-space: nowrap;
  }
}
@media (max-width: 899px) {
  .reports-tabs {
    flex-direction: column !important;
  }
  .reports-tabs .report-tab {
    width: 100%;
    text-align: left;
  }
}

/* ============================================================
   イベント操作: コンパクトツールバー
   ============================================================ */
.op-toolbar {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 24px;
}

.op-toolbar-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 10px;
  padding: 12px 14px;
  background: var(--bg-panel);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
}

.op-toolbar-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  width: 100%;
  margin-bottom: 2px;
}

.op-tool-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 600;
  border-radius: 8px;
  border: 1px solid var(--border-subtle);
  background: var(--bg-hover);
  color: var(--text-primary);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, transform 0.1s;
}

.op-tool-btn .material-symbols-outlined {
  font-size: 18px;
  opacity: 0.9;
}

.op-tool-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
}

.op-tool-btn.primary { border-color: rgba(0, 212, 255, 0.35); color: var(--accent-cyan); }
.op-tool-btn.success { border-color: rgba(0, 255, 136, 0.35); color: var(--accent-green); }
.op-tool-btn.warn { border-color: rgba(255, 193, 7, 0.35); color: #ffc107; }
.op-tool-btn.cyan { border-color: rgba(0, 212, 255, 0.25); color: #5ce1e6; }
.op-tool-btn.orange { border-color: rgba(255, 149, 0, 0.35); color: #ff922b; }
.op-tool-btn.danger { border-color: rgba(255, 71, 87, 0.4); color: #ff6b81; }
.op-tool-btn.purple { border-color: rgba(240, 147, 251, 0.35); color: #f093fb; }
.op-tool-btn.neutral { opacity: 0.95; }

@media (min-width: 900px) {
  .op-toolbar-group {
    flex-wrap: nowrap;
  }
  .op-toolbar-label {
    width: auto;
    margin: 0 8px 0 0;
    align-self: center;
  }
}
