/* =========================================================================
   ui.css — 社内ツール共通デザインシステム (v1.0)
   ========================================================================= */

:root {
  /* === Colors（i-cept.jp パレット — 純白＋オレンジ＋グレー） === */
  --bg:           #ffffff;
  --bg-elev:     #fff8f2;
  --panel:       #ffffff;
  --ink:         #333333;
  --ink-2:       #444444;
  --sub:         #777777;
  --sub-2:       #999999;
  --line:        #e5e5e5;
  --line-2:      #cccccc;
  --hover:       #fff8f2;

  --accent:      #ff7f00;
  --accent-2:    #e07000;
  --accent-soft: #fff8f2;
  --accent-line: #ffe2cc;

  --ok:          #047857;
  --ok-soft:     #ecfdf5;
  --ok-line:     #a7f3d0;

  --warn:        #b45309;
  --warn-soft:   #fffbeb;
  --warn-line:   #fde68a;

  --danger:      #cc2727;
  --danger-soft: #fef2f2;
  --danger-line: #fecaca;

  --info:        #0369a1;
  --info-soft:   #f0f9ff;
  --info-line:   #bae6fd;

  /* === Spacing === */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px;  --sp-4: 16px;
  --sp-5: 20px; --sp-6: 24px; --sp-8: 32px;  --sp-10: 40px;

  /* === Type === */
  --font: "BIZ UDPGothic","BIZ UDPゴシック",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --fs-xs: 11px; --fs-sm: 12px; --fs-base: 13px; --fs-md: 14px;
  --fs-lg: 16px; --fs-xl: 20px; --fs-2xl: 24px;

  /* === Radius / Shadow === */
  --r-1: 3px; --r-2: 4px; --r-3: 6px; --r-4: 8px; --r-pill: 999px;
  --sh-1: 0 1px 2px rgba(0,0,0,0.04);
  --sh-2: 0 2px 8px rgba(0,0,0,0.06);
  --sh-3: 0 4px 16px rgba(0,0,0,0.10);

  /* === Transitions === */
  --t-fast: 0.12s ease;
  --t-mid:  0.2s ease;
}

/* === Reset === */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--ink);
  font-size: var(--fs-md);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--accent); text-decoration: none; transition: color var(--t-fast); }
a:hover { text-decoration: underline; color: var(--accent-2); }

/* === Lucide icon baseline === */
[class^="lucide-"], [class*=" lucide-"] {
  display: inline-block;
  vertical-align: -0.125em;
  font-size: 1em;
  line-height: 1;
}

/* === Layout === */
.wrap { max-width: 1500px; margin: 0 auto; padding: var(--sp-4) var(--sp-4) 60px; }
.wrap-md { max-width: 1200px; margin: 0 auto; padding: var(--sp-4) var(--sp-4) 60px; }
.wrap-sm { max-width: 900px; margin: 0 auto; padding: var(--sp-4) var(--sp-4) 60px; }

.back-link { display: inline-block; font-size: var(--fs-sm); color: var(--sub); margin-bottom: var(--sp-2); }
.back-link:hover { color: var(--accent); }

header.app-header {
  border-bottom: 2px solid var(--ink);
  padding-bottom: var(--sp-3);
  margin-bottom: var(--sp-4);
  display: flex; align-items: flex-end; gap: var(--sp-3); flex-wrap: wrap;
}
header.app-header > div:first-child { flex: 1; }
.app-title { font-size: var(--fs-xl); font-weight: 700; margin: 0 0 var(--sp-1); }
.app-lead  { color: var(--sub); font-size: var(--fs-sm); margin: 0; }

/* === Cards === */
.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-2);
  padding: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-3);
  transition: box-shadow var(--t-mid), border-color var(--t-fast);
}
.card.hoverable:hover { box-shadow: var(--sh-2); border-color: var(--line-2); }
.card h2 {
  font-size: var(--fs-base);
  font-weight: 700;
  margin: 0 0 var(--sp-2);
  color: var(--sub);
  letter-spacing: 0.06em;
}
.card-row { display: flex; gap: var(--sp-2); align-items: center; flex-wrap: wrap; }

/* === Buttons === */
.btn, button.btn {
  font-family: inherit;
  font-size: var(--fs-base);
  font-weight: 600;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--ink);
  border-radius: var(--r-1);
  padding: 5px 12px;
  cursor: pointer;
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.btn:hover { background: var(--hover); border-color: var(--line-2); }
.btn:active { transform: translateY(1px); }
.btn.primary, button.btn.primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn.primary:hover { background: var(--accent-2); border-color: var(--accent-2); }
.btn.danger { color: var(--danger); border-color: var(--danger-line); background: var(--panel); }
.btn.danger:hover { background: var(--danger-soft); }
.btn.ghost { background: transparent; border-color: transparent; color: var(--sub); }
.btn.ghost:hover { background: var(--hover); color: var(--ink); }
.btn.sm { padding: 3px 8px; font-size: var(--fs-sm); }
.btn.lg { padding: 8px 16px; font-size: var(--fs-md); }

/* === Form === */
input, select, textarea {
  font-family: inherit;
  font-size: var(--fs-base);
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--ink);
  border-radius: var(--r-1);
  padding: 5px 10px;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255,127,0,0.18);
}
label.field { display: block; font-size: var(--fs-sm); color: var(--sub); margin-bottom: var(--sp-2); }
label.field > span { display: block; margin-bottom: var(--sp-1); }
label.field input, label.field select, label.field textarea { width: 100%; }

/* === Table === */
table.dt { width: 100%; border-collapse: collapse; font-size: var(--fs-base); }
table.dt th, table.dt td { border: 1px solid var(--line); padding: 6px 8px; text-align: left; vertical-align: middle; }
table.dt th { background: var(--bg-elev); font-weight: 600; color: var(--sub); font-size: var(--fs-sm); letter-spacing: 0.04em; }
table.dt td.num, table.dt th.num { text-align: right; font-variant-numeric: tabular-nums; }
table.dt tr.total td { background: var(--bg-elev); font-weight: 700; }
table.dt tr:hover td:not([class*="bg-"]) { background: var(--hover); }
.table-wrap { overflow-x: auto; }
.table-wrap.scroll-y { max-height: 60vh; overflow-y: auto; }

/* === Badge / Tag / Status === */
.badge {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: 700;
  padding: 1px 6px;
  border-radius: var(--r-1);
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.badge.ok      { background: var(--ok-soft);     color: var(--ok);     border: 1px solid var(--ok-line); }
.badge.warn    { background: var(--warn-soft);   color: var(--warn);   border: 1px solid var(--warn-line); }
.badge.danger  { background: var(--danger-soft); color: var(--danger); border: 1px solid var(--danger-line); }
.badge.info    { background: var(--info-soft);   color: var(--info);   border: 1px solid var(--info-line); }
.badge.neutral { background: var(--bg-elev);     color: var(--sub);    border: 1px solid var(--line); }
.badge.solid   { background: var(--accent); color: #fff; border-color: var(--accent); }

.tag {
  display: inline-block;
  font-size: var(--fs-xs);
  padding: 2px 8px;
  border-radius: var(--r-pill);
  background: var(--bg);
  color: var(--sub);
  border: 1px solid var(--line);
  letter-spacing: 0.04em;
}

.role-badge {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: 600;
  padding: 1px 8px;
  border-radius: var(--r-1);
  background: var(--ok-soft);
  color: var(--ok);
  border: 1px solid var(--ok-line);
}
.role-badge.admin { background: var(--danger-soft); color: var(--danger); border-color: var(--danger-line); }

/* === KPI Card === */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--sp-3);
}
.kpi {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  padding: var(--sp-3) var(--sp-4);
  display: flex; flex-direction: column; gap: 2px;
  transition: box-shadow var(--t-mid), transform var(--t-fast);
  cursor: pointer; text-decoration: none; color: inherit;
}
.kpi:hover { box-shadow: var(--sh-2); transform: translateY(-1px); text-decoration: none; }
.kpi-label { font-size: var(--fs-xs); color: var(--sub); letter-spacing: 0.04em; text-transform: uppercase; }
.kpi-value { font-size: var(--fs-2xl); font-weight: 800; color: var(--ink); font-variant-numeric: tabular-nums; line-height: 1.2; }
.kpi-unit  { font-size: var(--fs-sm); color: var(--sub); margin-left: 2px; font-weight: 400; }
.kpi-sub   { font-size: var(--fs-xs); color: var(--sub); margin-top: 2px; display: flex; align-items: center; gap: 4px; }
.kpi-trend.up   { color: var(--ok); }
.kpi-trend.down { color: var(--danger); }
.kpi-prog { background: var(--line); height: 6px; border-radius: var(--r-pill); overflow: hidden; margin-top: var(--sp-2); }
.kpi-prog > span { display: block; height: 100%; background: var(--accent); transition: width 0.4s ease; }
.kpi-prog.over > span { background: var(--ok); }
.kpi-prog.warn > span { background: var(--warn); }

/* === Action List === */
.action-list { list-style: none; padding: 0; margin: 0; }
.action-item {
  display: flex; gap: var(--sp-3); align-items: flex-start;
  padding: var(--sp-3) var(--sp-2);
  border-bottom: 1px solid var(--line);
  transition: background var(--t-fast);
  cursor: pointer; text-decoration: none; color: inherit;
}
.action-item:last-child { border-bottom: none; }
.action-item:hover { background: var(--hover); text-decoration: none; }
.action-icon { font-size: 18px; line-height: 1; padding-top: 2px; }
.action-body { flex: 1; min-width: 0; }
.action-title { font-weight: 600; font-size: var(--fs-md); color: var(--ink); margin-bottom: 2px; }
.action-meta { font-size: var(--fs-xs); color: var(--sub); }

/* === Activity feed === */
.activity-list { display: flex; flex-direction: column; gap: var(--sp-2); }
.activity-item { display: flex; gap: var(--sp-2); align-items: center; font-size: var(--fs-sm); color: var(--sub); }
.activity-item .who { font-weight: 600; color: var(--ink); }
.activity-item .when { color: var(--sub-2); font-size: var(--fs-xs); margin-left: auto; white-space: nowrap; }

/* === Empty State === */
.empty-state {
  text-align: center;
  padding: var(--sp-10) var(--sp-4);
  color: var(--sub);
}
.empty-state .empty-icon { font-size: 32px; opacity: 0.4; margin-bottom: var(--sp-2); }
.empty-state .empty-title { font-size: var(--fs-md); font-weight: 600; color: var(--ink-2); margin-bottom: var(--sp-1); }
.empty-state .empty-desc { font-size: var(--fs-sm); margin-bottom: var(--sp-3); }

/* === Skeleton Loading === */
.skeleton {
  background: linear-gradient(90deg, var(--line) 0%, var(--bg-elev) 50%, var(--line) 100%);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.4s ease-in-out infinite;
  border-radius: var(--r-1);
}
@keyframes skeleton-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.skeleton-line { height: 14px; margin: 6px 0; }
.skeleton-card { height: 80px; }

/* === Toast === */
.toast-stack {
  position: fixed; bottom: 20px; right: 20px;
  display: flex; flex-direction: column; gap: var(--sp-2);
  z-index: 1000;
}
.toast {
  background: var(--ink); color: #fff;
  padding: 10px 16px; border-radius: var(--r-2);
  font-size: var(--fs-sm); box-shadow: var(--sh-3);
  opacity: 0; transform: translateY(8px);
  transition: opacity var(--t-mid), transform var(--t-mid);
  display: flex; align-items: center; gap: var(--sp-2);
  max-width: 380px;
}
.toast.show { opacity: 1; transform: translateY(0); }
.toast.success { background: var(--ok); }
.toast.error   { background: var(--danger); }
.toast.warn    { background: var(--warn); }
.toast.info    { background: var(--info); }
.toast-icon { font-size: 16px; line-height: 1; }

/* === Modal === */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,0.4);
  display: flex; align-items: center; justify-content: center;
  z-index: 900; padding: var(--sp-4);
  opacity: 0; transition: opacity var(--t-mid);
}
.modal-backdrop.show { opacity: 1; }
.modal {
  background: var(--panel); border-radius: var(--r-3);
  padding: var(--sp-5);
  max-width: 480px; width: 100%;
  box-shadow: var(--sh-3);
  transform: translateY(8px); transition: transform var(--t-mid);
}
.modal-backdrop.show .modal { transform: translateY(0); }
.modal h3 { margin: 0 0 var(--sp-3); font-size: var(--fs-lg); }
.modal .modal-body { margin-bottom: var(--sp-4); color: var(--ink-2); }
.modal .modal-actions { display: flex; gap: var(--sp-2); justify-content: flex-end; }

/* === Command Palette === */
.cmd-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,0.5);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 10vh;
  z-index: 950; opacity: 0; transition: opacity var(--t-fast);
  pointer-events: none;
}
.cmd-backdrop.show { opacity: 1; pointer-events: auto; }
.cmd-palette {
  background: var(--panel); border-radius: var(--r-3);
  width: 100%; max-width: 600px;
  max-height: 70vh; overflow: hidden;
  box-shadow: var(--sh-3);
  display: flex; flex-direction: column;
  transform: translateY(-8px); transition: transform var(--t-mid);
}
.cmd-backdrop.show .cmd-palette { transform: translateY(0); }
.cmd-input {
  border: none; border-bottom: 1px solid var(--line);
  padding: var(--sp-4); font-size: var(--fs-lg);
  border-radius: 0;
}
.cmd-input:focus { outline: none; box-shadow: none; border-bottom-color: var(--accent); }
.cmd-results { overflow-y: auto; max-height: calc(70vh - 60px); padding: var(--sp-2); }
.cmd-section-label {
  font-size: var(--fs-xs); color: var(--sub); padding: var(--sp-2) var(--sp-3) var(--sp-1);
  letter-spacing: 0.05em; text-transform: uppercase; font-weight: 600;
}
.cmd-item {
  padding: var(--sp-2) var(--sp-3); border-radius: var(--r-2);
  cursor: pointer; font-size: var(--fs-md);
  display: flex; align-items: center; gap: var(--sp-3);
}
.cmd-item.active { background: var(--accent-soft); color: var(--accent-2); }
.cmd-item-icon { font-size: 14px; opacity: 0.6; }
.cmd-item-title { font-weight: 500; }
.cmd-item-meta { font-size: var(--fs-xs); color: var(--sub); margin-left: auto; }
.cmd-empty { text-align: center; padding: var(--sp-8); color: var(--sub); font-size: var(--fs-sm); }
.cmd-hint {
  border-top: 1px solid var(--line); padding: var(--sp-2) var(--sp-3);
  font-size: var(--fs-xs); color: var(--sub); display: flex; gap: var(--sp-3);
}
.cmd-hint kbd {
  font-family: inherit; font-size: 10px; padding: 1px 5px;
  border: 1px solid var(--line-2); border-radius: 3px;
  background: var(--bg-elev); margin-right: 3px;
}

/* === Greeting / Hero（i-cept 風：白背景＋オレンジアクセント） === */
.greeting {
  background: var(--panel);
  border: 1px solid var(--line);
  border-top: 3px solid var(--accent);
  color: var(--ink);
  padding: var(--sp-5) var(--sp-6);
  border-radius: var(--r-3); margin-bottom: var(--sp-4);
  display: flex; justify-content: space-between; align-items: flex-end; gap: var(--sp-4);
  flex-wrap: wrap;
}
.greeting-title { font-size: var(--fs-xl); font-weight: 700; margin: 0; color: var(--ink); }
.greeting-sub { font-size: var(--fs-sm); color: var(--sub); margin-top: 2px; }
.greeting-meta { font-size: var(--fs-sm); color: var(--sub); text-align: right; }

/* === Section === */
.section-title {
  font-size: var(--fs-base); font-weight: 700; color: var(--sub);
  letter-spacing: 0.08em; margin: var(--sp-5) 0 var(--sp-3);
  text-transform: uppercase;
  display: flex; align-items: center; gap: var(--sp-2);
}
.section-title .count { background: var(--bg-elev); padding: 1px 8px; border-radius: var(--r-pill); font-size: var(--fs-xs); }

/* === Tools grid === */
.tools-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
}
@media (max-width: 900px) { .tools-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .tools-grid { grid-template-columns: 1fr; } }

.tool-card {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--r-2); padding: var(--sp-4);
  display: flex; flex-direction: column; gap: var(--sp-2);
  text-decoration: none; color: inherit;
  transition: border-color var(--t-fast), box-shadow var(--t-mid);
  position: relative;
}
.tool-card:hover { border-color: var(--accent); box-shadow: var(--sh-2); text-decoration: none; }
.tool-card-head { display: flex; justify-content: space-between; align-items: baseline; gap: var(--sp-2); }
.tool-name { font-size: var(--fs-lg); font-weight: 700; color: var(--ink); }
.tool-desc { font-size: var(--fs-sm); color: var(--sub); margin: 0; flex: 1; }
.tool-meta { display: flex; gap: var(--sp-1); flex-wrap: wrap; margin-top: var(--sp-1); }
.tool-card .badge-count {
  position: absolute; top: var(--sp-2); right: var(--sp-2);
  font-size: var(--fs-xs); font-weight: 700; padding: 1px 7px;
  border-radius: var(--r-pill); background: var(--danger); color: #fff;
}
.tool-card .badge-count.warn   { background: var(--warn); }
.tool-card .badge-count.info   { background: var(--info); }

/* === Status indicators === */
.status-live  { font-size: var(--fs-xs); font-weight: 600; padding: 1px 8px; border-radius: var(--r-1); background: var(--ok-soft); color: var(--ok); border: 1px solid var(--ok-line); }
.status-wip   { font-size: var(--fs-xs); font-weight: 600; padding: 1px 8px; border-radius: var(--r-1); background: var(--warn-soft); color: var(--warn); border: 1px solid var(--warn-line); }
.status-admin { font-size: var(--fs-xs); font-weight: 600; padding: 1px 8px; border-radius: var(--r-1); background: var(--danger-soft); color: var(--danger); border: 1px solid var(--danger-line); }

/* === Breadcrumb === */
.breadcrumb {
  font-size: var(--fs-sm); color: var(--sub);
  margin-bottom: var(--sp-2); display: flex; gap: var(--sp-2); align-items: center;
}
.breadcrumb a { color: var(--sub); }
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb .sep { opacity: 0.5; }

/* === Utility === */
.flex { display: flex; }
.flex-1 { flex: 1; }
.gap-1 { gap: var(--sp-1); } .gap-2 { gap: var(--sp-2); } .gap-3 { gap: var(--sp-3); }
.items-center { align-items: center; } .items-end { align-items: flex-end; }
.justify-between { justify-content: space-between; } .justify-end { justify-content: flex-end; }
.flex-wrap { flex-wrap: wrap; }
.text-sub { color: var(--sub); }
.text-xs { font-size: var(--fs-xs); } .text-sm { font-size: var(--fs-sm); }
.mt-1 { margin-top: var(--sp-1); } .mt-2 { margin-top: var(--sp-2); } .mt-3 { margin-top: var(--sp-3); }
.mb-2 { margin-bottom: var(--sp-2); } .mb-3 { margin-bottom: var(--sp-3); }
.hidden { display: none !important; }

/* === Role-based visibility === */
body:not(.can-see-money) .money-col,
body:not(.can-see-money) .money-only { display: none !important; }
body:not(.dept-1ka):not(.is-admin) .dept-1ka-only { display: none !important; }
body:not(.is-admin) .admin-only { display: none !important; }

/* === Mobile === */
@media (max-width: 600px) {
  .wrap, .wrap-md, .wrap-sm { padding: var(--sp-3); }
  header.app-header { gap: var(--sp-2); }
  .greeting { padding: var(--sp-4); flex-direction: column; align-items: flex-start; }
  .greeting-meta { text-align: left; }
  .kpi-value { font-size: var(--fs-xl); }
  table.dt th, table.dt td { padding: 4px 6px; font-size: var(--fs-sm); }
  .toolbar { flex-wrap: wrap; gap: var(--sp-2); }
  .cmd-palette { max-width: 100%; }
  .greeting-meta { width: 100%; }
}

/* Pipeline mobile：横スクロール */
@media (max-width: 800px) {
  .board {
    grid-template-columns: repeat(5, 280px) !important;
    overflow-x: auto;
    padding-bottom: var(--sp-3);
    scroll-snap-type: x mandatory;
  }
  .board > .col { scroll-snap-align: start; }
}
