/* ============================================================
   案件マネージャー — assets/style.css
   ============================================================ */
:root{
  --bg:#0f1117;--s1:#1a1d27;--s2:#242836;--s3:#2e3344;
  --bd:#353a4a;--t1:#e8eaef;--t2:#9ba1b4;--t3:#6b7185;
  --accent:#6c8cff;--accent2:#4a6aee;--ag:rgba(108,140,255,.15);
  --green:#34d399;--gbg:rgba(52,211,153,.12);
  --red:#f87171;--rbg:rgba(248,113,113,.1);
  --orange:#fb923c;--obg:rgba(251,146,60,.1);
  --yellow:#fbbf24;--purple:#a78bfa;--cyan:#22d3ee;
  --r:10px;--sh:0 4px 24px rgba(0,0,0,.3);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body,.anken-app{background:var(--bg);color:var(--t1);font-family:'Noto Sans JP','DM Sans',sans-serif;min-height:100vh;font-size:14px;line-height:1.5}

/* ── Topbar ── */
.topbar{background:var(--s1);border-bottom:1px solid var(--bd);padding:0 24px;display:flex;align-items:center;gap:8px;height:56px;position:sticky;top:0;z-index:100}
.topbar-logo{font-family:'DM Sans',sans-serif;font-weight:700;font-size:18px;color:var(--accent);letter-spacing:-.5px;margin-right:24px;display:flex;align-items:center;gap:8px}
.topbar-logo svg{width:24px;height:24px}
.fy-sel{display:flex;align-items:center;gap:4px;margin-right:16px}
.fy-arrow{background:0 0;border:1px solid var(--bd);color:var(--t2);width:28px;height:28px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:.12s}
.fy-arrow:hover{background:var(--s2);color:var(--t1);border-color:var(--t3)}
.fy-label{font-size:13px;font-weight:600;color:var(--t1);min-width:120px;text-align:center}
.fy-sub{font-size:10px;color:var(--t3);font-weight:400;display:block}
.topbar-nav{display:flex;gap:2px}
.nav-btn{background:0 0;border:0;color:var(--t2);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;transition:.15s}
.nav-btn:hover{background:var(--s2);color:var(--t1)}
.nav-btn.active{background:var(--ag);color:var(--accent)}
.topbar-right{margin-left:auto;display:flex;gap:8px;align-items:center}

/* ── Buttons ── */
.btn-pri{background:var(--accent);color:#fff;border:0;padding:8px 18px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:.15s;display:inline-flex;align-items:center;gap:6px}
.btn-pri:hover{background:var(--accent2);transform:translateY(-1px)}
.btn-pri:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-sec{background:var(--s3);border:1px solid var(--bd);color:var(--t1);padding:8px 18px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;transition:.15s}
.btn-sec:hover{background:var(--s2);border-color:var(--t3)}
.btn-sm{font-size:12px!important;padding:6px 12px!important}
.btn-del{background:var(--rbg);border:1px solid rgba(248,113,113,.3);color:var(--red);padding:8px 18px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;margin-right:auto}
.btn-del:hover{background:rgba(248,113,113,.2)}
.edit-btn{background:var(--s3);border:1px solid var(--bd);color:var(--t2);padding:4px 10px;border-radius:5px;cursor:pointer;font-size:11px;font-family:inherit;transition:.12s}
.edit-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ── Pages ── */
.page{padding:24px;max-width:1500px;margin:0 auto;width:100%;display:none}
.page.active{display:block}

/* ── Dashboard ── */
.dash-head{margin-bottom:24px}
.dash-head h2{font-size:22px;font-weight:700}
.dash-head p{color:var(--t2);font-size:13px;margin-top:4px}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.kpi{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);padding:20px;position:relative;overflow:hidden}
.kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.kpi.blue::before{background:linear-gradient(90deg,var(--accent),var(--cyan))}
.kpi.green::before{background:linear-gradient(90deg,var(--green),#6ee7b7)}
.kpi.orange::before{background:linear-gradient(90deg,var(--orange),var(--yellow))}
.kpi.purple::before{background:linear-gradient(90deg,var(--purple),#c4b5fd)}
.kpi-lbl{font-size:12px;color:var(--t2);font-weight:500;letter-spacing:.5px}
.kpi-val{font-size:28px;font-weight:700;margin:8px 0 4px;font-family:'DM Sans',sans-serif}
.kpi-sub{font-size:12px;color:var(--t3)}
.green-t{color:var(--green)}
.accent-t{color:var(--accent)}

.charts-row{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:24px}
.card{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);padding:20px}
.card h3{font-size:14px;font-weight:600;margin-bottom:16px}
.legend{display:flex;gap:16px;margin-bottom:12px;font-size:11px;color:var(--t2)}
.lg{display:flex;align-items:center;gap:5px}
.lg i{width:12px;height:8px;border-radius:2px;display:inline-block}

.mtbl{width:100%;border-collapse:collapse;font-size:13px}
.mtbl th{text-align:left;padding:8px 10px;color:var(--t2);font-weight:500;font-size:11px;letter-spacing:.5px;border-bottom:1px solid var(--bd)}
.mtbl td{padding:8px 10px;border-bottom:1px solid rgba(53,58,74,.5)}
.mtbl tr:hover td{background:var(--s2)}

.bar-c{display:flex;align-items:center;gap:8px}
.bar-bg{flex:1;height:8px;background:var(--s3);border-radius:4px;overflow:hidden;position:relative}
.bar-f{height:100%;border-radius:4px;transition:width .3s;position:absolute;left:0;top:0}
.bar-f.good{background:var(--green)}.bar-f.mid{background:var(--orange)}.bar-f.low{background:var(--red)}.bar-f.fc{background:var(--accent);opacity:.4}
.bar-p{font-size:11px;color:var(--t2);min-width:40px;text-align:right}

.si-wrap{display:flex;flex-direction:column;gap:10px}
.si-row{display:flex;align-items:center;gap:10px;font-size:13px}
.si-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.si-name{min-width:80px;font-size:12px}
.si-bar{flex:1;height:6px;background:var(--s3);border-radius:3px;overflow:hidden}
.si-fill{height:100%;border-radius:3px}
.si-cnt{font-size:12px;color:var(--t2);min-width:24px;text-align:right}

/* ── List ── */
.list-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.vtabs{display:flex;gap:2px;background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:3px}
.vtab{background:0 0;border:0;color:var(--t2);padding:6px 14px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;font-family:inherit;transition:.15s}
.vtab:hover{color:var(--t1)}
.vtab.active{background:var(--accent);color:#fff}
.sbox{display:flex;align-items:center;gap:8px;background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:0 12px}
.sbox input{background:0 0;border:0;color:var(--t1);padding:8px 0;font-size:13px;width:200px;outline:0;font-family:inherit}
.sbox input::placeholder{color:var(--t3)}
.si{color:var(--t3);font-size:14px}
.frow{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.fsel{background:var(--s1);border:1px solid var(--bd);color:var(--t1);padding:6px 12px;border-radius:6px;font-size:12px;font-family:inherit;cursor:pointer}
.fsel:focus{border-color:var(--accent);outline:0}
.fcnt{font-size:12px;color:var(--t3);align-self:center}

.tw{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);overflow-x:auto}
.dtbl{width:100%;border-collapse:collapse;font-size:12px;white-space:nowrap}
.dtbl th{padding:10px 12px;text-align:left;font-weight:600;font-size:11px;color:var(--t2);letter-spacing:.3px;background:var(--s2);border-bottom:1px solid var(--bd);position:sticky;top:0}
.dtbl td{padding:8px 12px;border-bottom:1px solid rgba(53,58,74,.4)}
.dtbl tbody tr{transition:background .1s;cursor:pointer}
.dtbl tbody tr:hover{background:var(--s2)}

.badge{display:inline-flex;padding:3px 8px;border-radius:5px;font-size:11px;font-weight:600;white-space:nowrap}
.b-bl{background:rgba(108,140,255,.15);color:var(--accent)}
.b-gn{background:var(--gbg);color:var(--green)}
.b-or{background:var(--obg);color:var(--orange)}
.b-rd{background:var(--rbg);color:var(--red)}
.b-pu{background:rgba(167,139,250,.15);color:var(--purple)}
.b-gy{background:rgba(107,113,133,.2);color:var(--t2)}
.b-cy{background:rgba(34,211,238,.12);color:var(--cyan)}
.b-yw{background:rgba(251,191,36,.15);color:var(--yellow)}
.tb{font-size:10px}
.amt-c{font-family:'DM Sans',sans-serif;font-weight:500}
.pos{color:var(--green)}.neg{color:var(--red)}
.empty-td{text-align:center;padding:40px 20px!important;color:var(--t3);font-size:13px}

/* ── Modal ── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
.overlay.open{display:flex}
.modal{background:var(--s1);border:1px solid var(--bd);border-radius:14px;width:100%;max-width:780px;max-height:90vh;overflow-y:auto;box-shadow:var(--sh)}
.modal-sm{max-width:520px}
.mh{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--bd);position:sticky;top:0;background:var(--s1);z-index:1;border-radius:14px 14px 0 0}
.mh h2{font-size:17px;font-weight:700}
.mx{background:0 0;border:0;color:var(--t2);font-size:22px;cursor:pointer;padding:4px;line-height:1;border-radius:6px;transition:.12s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}
.mx:hover{background:var(--s3);color:var(--t1)}
.mb{padding:24px}
.mf{padding:16px 24px;border-top:1px solid var(--bd);display:flex;justify-content:flex-end;gap:8px;position:sticky;bottom:0;background:var(--s1);border-radius:0 0 14px 14px}

.sec-t{font-size:13px;font-weight:600;color:var(--accent);margin:18px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--bd)}
.sec-t:first-child{margin-top:0}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fi{display:flex;flex-direction:column;gap:4px}
.fi.full{grid-column:1/-1}
.fi label{font-size:12px;font-weight:500;color:var(--t2)}
.fi input,.fi select,.fi textarea{background:var(--s2);border:1px solid var(--bd);color:var(--t1);padding:9px 12px;border-radius:7px;font-size:13px;font-family:inherit;transition:border .15s;width:100%}
.fi input:focus,.fi select:focus,.fi textarea:focus{border-color:var(--accent);outline:0;box-shadow:0 0 0 3px var(--ag)}
.fi input::placeholder,.fi textarea::placeholder{color:var(--t3)}
.fi textarea{min-height:70px;resize:vertical}

.cbox{background:var(--s3);border:1px solid var(--bd);border-radius:var(--r);padding:16px;margin-top:8px}
.cr{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px}
.cr.total{border-top:1px solid var(--bd);padding-top:10px;margin-top:4px;font-weight:700;font-size:15px}
.cr.profit{color:var(--green)}.cr.loss{color:var(--red)}

.tg-grid{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;align-items:center}
.tg-grid span{font-size:13px;font-weight:500}
.tg-grid input{background:var(--s2);border:1px solid var(--bd);color:var(--t1);padding:7px 10px;border-radius:6px;font-size:13px;font-family:inherit;width:100%}
.tg-grid input:focus{border-color:var(--accent);outline:0}

/* ── Toast ── */
.toast{position:fixed;bottom:24px;right:24px;z-index:3000;padding:12px 20px;border-radius:8px;font-size:13px;font-weight:500;animation:tIn .3s ease-out;max-width:400px}
.toast.ok{background:var(--gbg);color:var(--green);border:1px solid rgba(52,211,153,.3)}
.toast.err{background:var(--rbg);color:var(--red);border:1px solid rgba(248,113,113,.3)}
@keyframes tIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ── Responsive ── */
@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.charts-row{grid-template-columns:1fr}.fg{grid-template-columns:1fr}}
@media(max-width:600px){.kpi-grid{grid-template-columns:1fr}.topbar{padding:8px 12px;flex-wrap:wrap;height:auto}.page{padding:16px}}

/* ── Staff management ── */
.st-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--bd)}
.st-item:last-child{border-bottom:none}
.st-name{flex:1;font-size:13px;font-weight:500}
.st-del{background:none;border:none;color:var(--t3);cursor:pointer;font-size:16px;padding:2px 6px;border-radius:4px;transition:.12s;line-height:1}
.st-del:hover{color:var(--red);background:var(--rbg)}

/* ── Bulk delete ── */
.bulk-area{display:flex;align-items:center;gap:8px;margin-left:auto}
.bulk-cnt{font-size:12px;color:var(--accent);font-weight:600}
.chk-cell{width:36px;text-align:center}
.row-chk,.chk-all{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}
