
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F7F7F5;--sur:#fff;--sur2:#F2F1EE;--sur3:#E8E7E3;
  --bd:#E0DED8;--bd2:#C8C6BF;
  --tx:#1A1A18;--tx2:#4A4A47;--tx3:#888780;
  --gbg:#EAF3DE;--gtx:#27500A;--gbd:#97C459;
  --abg:#FAEEDA;--atx:#633806;--abd:#EF9F27;
  --bbg:#E6F1FB;--btx:#0C447C;--bbd:#85B7EB;
  --rbg:#FCEBEB;--rtx:#791F1F;
  --r:8px;--rl:12px;--fn:'Noto Sans JP',sans-serif;
}
html,body{height:100%;font-family:var(--fn);background:var(--bg);color:var(--tx);font-size:13px;line-height:1.5}
.app{display:flex;height:100vh}
.sb{width:196px;background:var(--sur);border-right:0.5px solid var(--bd);display:flex;flex-direction:column;flex-shrink:0;position:relative;transition:width .2s ease}
.sb.collapsed{width:52px}
.sb-logo{padding:14px 16px 10px;border-bottom:0.5px solid var(--bd);overflow:hidden;white-space:nowrap}
.sb-logo-t{font-size:13px;font-weight:600;color:var(--tx)}
.sb-logo-s{font-size:10px;color:var(--tx3);margin-top:1px}
.sb-nav{padding:6px 0;flex:1}
.sb-sec{padding:10px 16px 3px;font-size:10px;color:var(--tx3);font-weight:500;letter-spacing:.06em;text-transform:uppercase;overflow:hidden;white-space:nowrap}
.sb-item{display:flex;align-items:center;gap:8px;padding:7px 16px;font-size:12px;color:var(--tx2);cursor:pointer;transition:background .1s;user-select:none;text-decoration:none;white-space:nowrap;overflow:hidden;position:relative}
.sb-item:hover{background:var(--sur2);color:var(--tx)}
.sb-item.on{background:var(--bbg);color:var(--btx);font-weight:500}
.sb-item.dim{color:var(--tx3);cursor:default;pointer-events:none;opacity:.5}
.sb-item i{font-size:15px;flex-shrink:0}

/* === サイドバー折りたたみ === */
.sb.collapsed .sb-logo-t,
.sb.collapsed .sb-logo-s,
.sb.collapsed .sb-sec,
.sb.collapsed .sb-item-label{display:none}
.sb.collapsed .sb-logo{padding:14px 0 10px;text-align:center}
.sb.collapsed .sb-item{padding:9px 0;justify-content:center;gap:0}
.sb.collapsed .sb-item i{font-size:17px}
/* 折りたたみ時のホバーで項目名をツールチップ表示 */
.sb.collapsed .sb-item:hover::after{
  content:attr(data-label);
  position:absolute;left:100%;top:50%;transform:translateY(-50%);
  margin-left:6px;padding:5px 10px;
  background:#333;color:#fff;font-size:11px;font-weight:500;
  border-radius:4px;white-space:nowrap;
  z-index:1000;pointer-events:none;
  box-shadow:0 2px 6px rgba(0,0,0,.2);
}
/* トグルボタン（サイドバー右端） */
.sb-toggle{
  position:absolute;top:14px;right:-12px;
  width:24px;height:24px;border-radius:50%;
  background:var(--sur);border:0.5px solid var(--bd2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--tx2);
  font-family:var(--fn);font-size:11px;
  z-index:100;
  box-shadow:0 1px 3px rgba(0,0,0,.08);
  transition:all .15s;
}
.sb-toggle:hover{background:var(--bbg);color:var(--btx);border-color:var(--bbd)}
.sb-toggle:focus,
.sb-toggle:focus-visible{outline:2px solid #378ADD !important;outline-offset:2px;box-shadow:0 0 0 4px rgba(55,138,221,.25);background:var(--bbg);color:var(--btx)}
.sb-toggle i{font-size:14px;transition:transform .2s}
.sb.collapsed .sb-toggle i{transform:rotate(180deg)}

.main{position:relative;flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.tb{background:var(--sur);border-bottom:0.5px solid var(--bd);padding:9px 20px;display:flex;align-items:center;gap:10px;flex-shrink:0}
.tb-title{font-size:14px;font-weight:600;color:var(--tx)}
.dn{display:flex;align-items:center;gap:5px;margin-left:auto}
.dn-btn{background:none;border:0.5px solid var(--bd2);border-radius:var(--r);padding:3px 7px;cursor:pointer;color:var(--tx2);font-size:12px;font-family:var(--fn)}
.dn-btn:hover{background:var(--sur2)}
.dn-date{font-size:13px;font-weight:500;color:var(--tx);background:var(--sur2);border:0.5px solid var(--bd);border-radius:var(--r);padding:3px 12px;min-width:170px;text-align:center}
.dn-today{font-size:11px;color:var(--btx);background:var(--bbg);border:0.5px solid var(--bbd);border-radius:var(--r);padding:3px 8px;cursor:pointer;font-family:var(--fn);font-weight:500}
.sum{background:var(--sur2);border-bottom:0.5px solid var(--bd);padding:6px 20px;display:flex;gap:18px;align-items:center;flex-shrink:0}
.si{font-size:11px;color:var(--tx3)}
.si strong{font-weight:600;color:var(--tx);margin-left:3px}
.si.w strong{color:var(--atx)}
.si.g strong{color:var(--gtx)}
.cnt{flex:1;overflow-y:auto;padding:14px 20px}
.tw{background:var(--sur);border:0.5px solid var(--bd);border-radius:var(--rl);overflow:hidden}
table{width:100%;border-collapse:collapse;font-size:12px}
thead th{padding:7px 12px;background:var(--sur2);color:var(--tx3);font-weight:500;font-size:11px;border-bottom:0.5px solid var(--bd);white-space:nowrap;text-align:left}
th.r,td.r{text-align:right}
tbody td{padding:8px 12px;border-bottom:0.5px solid var(--bd);color:var(--tx);vertical-align:middle;white-space:nowrap}
tbody td.dim{color:var(--tx3)}
tbody td.sub{text-align:right;font-size:11px;color:var(--tx2)}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:#FAFAF8}
.tg{border-left:0.5px solid var(--bd)}
.bge{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:2px 7px;border-radius:20px;font-weight:500;white-space:nowrap}
.bg-ok{background:var(--gbg);color:var(--gtx)}
.bg-warn{background:var(--abg);color:var(--atx)}
.bg-none{background:var(--sur2);color:var(--tx3);border:0.5px solid var(--bd)}
.bg-zaiko{background:var(--gbg);color:var(--gtx)}
.bg-nyuka{background:var(--bbg);color:var(--btx)}
.btn-p{font-size:11px;background:var(--bbg);border:0.5px solid var(--bbd);border-radius:var(--r);padding:4px 10px;cursor:pointer;color:var(--btx);font-weight:500;font-family:var(--fn)}
.btn-p:hover{opacity:.85}
.btn-s{font-size:12px;background:var(--sur);border:0.5px solid var(--bd2);border-radius:var(--r);padding:4px 10px;cursor:pointer;color:var(--tx);display:inline-flex;align-items:center;gap:4px;font-family:var(--fn)}
.btn-s:hover{background:var(--sur2)}

.user-info{display:flex;align-items:center;gap:8px;padding-left:12px;border-left:0.5px solid var(--bd);margin-left:4px}
.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--tx2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}
.user-name{font-size:12px;font-weight:500;color:var(--tx)}
/* アカウントメニュー（プルダウン） */
.account-trigger{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:8px;font:inherit}
.account-trigger:hover{background:#f2f4f7}
.account-caret{font-size:10px;color:var(--tx2)}
.account-menu{position:absolute;top:100%;right:0;margin-top:6px;min-width:160px;background:#fff;border:1px solid var(--bd);border-radius:10px;box-shadow:0 8px 24px rgba(16,24,40,.12);padding:6px;z-index:1000}
.account-menu[hidden]{display:none}
.account-menu-item{display:block;width:100%;text-align:left;padding:8px 12px;border:none;background:none;border-radius:6px;cursor:pointer;font-size:13px;color:var(--tx)}
.account-menu-item:hover{background:#f9fafb}
.tb{position:relative}
.dn-center{position:absolute;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:5px}

/* === グローバルナビゲーション要素のフォーカス強調 === */
[data-nav-group]:focus,
[data-nav-group]:focus-visible{outline:2px solid #378ADD !important;outline-offset:2px;box-shadow:0 0 0 4px rgba(55,138,221,.2);border-radius:var(--r)}
[data-nav-group].sb-item:focus{background:var(--bbg);color:var(--btx)}

/* === 全要素キーボードナビ用フォーカス強調 === */
a:focus-visible,
button:focus-visible,
select:focus-visible{outline:2px solid #378ADD;outline-offset:2px;box-shadow:0 0 0 4px rgba(55,138,221,.2);border-radius:var(--r)}
.sb-item:focus-visible{background:var(--bbg);color:var(--btx);outline:none;box-shadow:inset 3px 0 0 var(--btx),0 0 0 2px rgba(55,138,221,.15)}
