/* ============================================================
   portal.css — AND Tools 案件ポータル（wireframe-studioとトーン統一）
   ============================================================ */
:root {
  --ui-bg:#f6f7f9; --ui-panel:#fff; --ui-border:#e4e7ec; --ui-border-strong:#d0d5dd;
  --ui-ink:#1d2330; --ui-ink-soft:#667085; --ui-accent:#4f46e5; --ui-accent-soft:#eef2ff;
  --ui-danger:#e5484d; --ui-radius:12px;
  --ui-shadow:0 1px 2px rgba(16,24,40,.06),0 1px 3px rgba(16,24,40,.10);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Helvetica Neue","Hiragino Sans","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;background:var(--ui-bg);color:var(--ui-ink);-webkit-font-smoothing:antialiased}
button,input,select,textarea{font-family:inherit}
button{cursor:pointer}

.topbar{height:56px;display:flex;align-items:center;gap:14px;padding:0 18px;background:var(--ui-panel);border-bottom:1px solid var(--ui-border);position:sticky;top:0;z-index:30}
.brand{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14px}
.brand__mark{width:24px;height:24px;border-radius:6px;background:var(--ui-ink);color:#fff;display:grid;place-items:center;font-size:13px}
.brand__sub{font-size:11px;font-weight:500;color:var(--ui-ink-soft);margin-left:2px}
.topbar__spacer{flex:1}

.btn{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 14px;border-radius:8px;border:1px solid var(--ui-border-strong);background:#fff;color:var(--ui-ink);font-size:13px;font-weight:600;white-space:nowrap}
.btn:hover{background:#f3f4f7}
.btn--primary{background:var(--ui-accent);border-color:var(--ui-accent);color:#fff}
.btn--primary:hover{background:#4338ca}
.btn--sm{height:30px;padding:0 10px;font-size:12px}
.icon-btn{width:26px;height:26px;border:0;background:transparent;border-radius:6px;display:grid;place-items:center;color:var(--ui-ink-soft)}
.icon-btn:hover{background:rgba(0,0,0,.06);color:var(--ui-ink)}
.icon-btn--danger:hover{background:#fde7e7;color:var(--ui-danger)}

.wrap{max-width:1180px;margin:0 auto;padding:36px 28px 90px}
.sec-head{margin-bottom:18px}
.sec-head h1{font-size:22px;margin:0}
.sec-head h2{font-size:16px;margin:0}
.sec-head p{margin:6px 0 0;color:var(--ui-ink-soft);font-size:13px}

/* 案件カード */
.case-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}
.case-empty{grid-column:1/-1;border:1.5px dashed var(--ui-border-strong);border-radius:var(--ui-radius);padding:46px 20px;text-align:center;color:var(--ui-ink-soft);font-size:13px;line-height:1.8}
.case-card{background:var(--ui-panel);border:1px solid var(--ui-border);border-radius:var(--ui-radius);box-shadow:var(--ui-shadow);padding:16px;display:flex;flex-direction:column;gap:10px}
.case-card__top{display:flex;align-items:flex-start;gap:8px}
.case-card__names{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.case-client{font-size:11px;font-weight:700;color:var(--ui-ink-soft);border:1px solid transparent;background:transparent;border-radius:5px;padding:2px 4px;width:100%}
.case-client:hover{background:#f3f4f7}
.case-client:focus{outline:none;background:#fff;border-color:var(--ui-accent)}
.case-name{font-size:15px;font-weight:700;border:1px solid transparent;background:transparent;border-radius:6px;padding:3px 4px;width:100%;color:var(--ui-ink)}
.case-name:hover{background:#f3f4f7}
.case-name:focus{outline:none;background:#fff;border-color:var(--ui-accent)}
.case-status{height:26px;border:1px solid var(--ui-border-strong);border-radius:999px;font-size:11px;font-weight:700;padding:0 8px;background:#fff;flex:none}
.case-status.st-act{color:#175cd3;border-color:#b2ccff;background:#eff4ff}
.case-status.st-wait{color:#b54708;border-color:#fedf89;background:#fffaeb}
.case-status.st-done{color:#067647;border-color:#abefc6;background:#ecfdf3}
.case-status.st-hold{color:#667085;background:#f3f4f7}

.case-links{display:flex;flex-direction:column;gap:6px}
.case-link{display:flex;align-items:center;gap:8px;border:1px solid var(--ui-border);border-radius:9px;padding:8px 10px}
.case-link__ico{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff;background:var(--ui-ink);flex:none}
.case-link__ico--p{background:var(--ui-accent)}
.case-link__main{flex:1;min-width:0;font-size:12px}
.case-link__main b{display:block;font-size:12px}
.case-link__main small{color:var(--ui-ink-soft);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.case-link .btn--sm{flex:none}
.case-link.is-soon{opacity:.55}

.case-card__foot{display:flex;align-items:center;gap:6px;border-top:1px solid var(--ui-border);padding-top:9px;margin-top:2px}
.case-date{font-size:11px;color:var(--ui-ink-soft);flex:1}

/* ツール */
.tools-sec{margin-top:44px;padding-top:26px;border-top:1px solid var(--ui-border)}
.tool-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px;margin-top:14px}
.tool-card{display:flex;align-items:center;gap:12px;background:var(--ui-panel);border:1px solid var(--ui-border);border-radius:var(--ui-radius);box-shadow:var(--ui-shadow);padding:14px 16px;text-decoration:none;color:var(--ui-ink)}
a.tool-card:hover{border-color:var(--ui-accent);box-shadow:0 4px 14px rgba(79,70,229,.14)}
.tool-card.is-soon{opacity:.55}
.tool-card__mark{width:34px;height:34px;border-radius:9px;background:var(--ui-ink);color:#fff;display:grid;place-items:center;font-weight:700;flex:none}
.tool-card__mark--p{background:var(--ui-accent)}
.tool-card b{font-size:14px;display:block}
.tool-card small{font-size:11px;color:var(--ui-ink-soft)}

/* モーダル・トースト */
.modal-backdrop{position:fixed;inset:0;background:rgba(16,24,40,.45);display:none;align-items:center;justify-content:center;z-index:100}
.modal-backdrop.is-open{display:flex}
.modal{background:#fff;border-radius:14px;width:min(480px,92vw);max-height:86vh;overflow:auto;box-shadow:0 20px 60px rgba(16,24,40,.3);padding:22px}
.modal h2{margin:0 0 14px;font-size:17px}
.field-row{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.field-row label{font-size:12px;font-weight:600;color:var(--ui-ink-soft)}
.field-row input,.field-row select{height:38px;border:1px solid var(--ui-border-strong);border-radius:8px;padding:0 10px;font-size:14px}
.field-row input:focus,.field-row select:focus{outline:none;border-color:var(--ui-accent)}
.modal__foot{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}

.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ui-ink);color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;font-weight:600;box-shadow:0 10px 30px rgba(0,0,0,.25);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:200}
.toast.is-show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============================================================
   横断ダッシュボード
   ============================================================ */
.hub{margin-bottom:40px}
.hub-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.hub-stat{background:var(--ui-panel);border:1px solid var(--ui-border);border-radius:var(--ui-radius);box-shadow:var(--ui-shadow);padding:14px 16px}
.hub-stat__n{font-size:28px;font-weight:800;line-height:1.1}
.hub-stat__l{font-size:12px;color:var(--ui-ink-soft);margin-top:3px}
.hub-stat.is-warn .hub-stat__n{color:#b54708}
.hub-stat.is-danger .hub-stat__n{color:var(--ui-danger)}

.hub-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hub-panel{background:var(--ui-panel);border:1px solid var(--ui-border);border-radius:var(--ui-radius);box-shadow:var(--ui-shadow);padding:14px 16px}
.hub-panel h3{font-size:14px;margin:0 0 10px}
.hub-empty{font-size:13px;color:var(--ui-ink-soft);padding:18px 4px;text-align:center}

.hub-tasklist{display:flex;flex-direction:column;gap:2px;max-height:340px;overflow-y:auto}
.hub-tsec{font-size:11px;font-weight:700;color:var(--ui-ink-soft);margin:8px 2px 4px}
.hub-task{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:8px;text-decoration:none;color:var(--ui-ink)}
.hub-task:hover{background:#f3f4f7}
.hub-dot{width:9px;height:9px;border-radius:50%;flex:none}
.hub-task__main{flex:1;min-width:0}
.hub-task__main b{display:block;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hub-task__main small{font-size:11px;color:var(--ui-ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.hub-task__due{font-size:12px;font-weight:700;color:var(--ui-ink-soft);flex:none}
.hub-task__due.over{color:var(--ui-danger)}
.hub-more{font-size:11px;color:var(--ui-ink-soft);padding:4px 8px}

.hub-proglist{display:flex;flex-direction:column;gap:10px;max-height:340px;overflow-y:auto}
.hub-prog{display:block;text-decoration:none;color:var(--ui-ink);padding:6px 6px;border-radius:8px}
.hub-prog:hover{background:#f3f4f7}
.hub-prog__top{display:flex;justify-content:space-between;gap:8px;font-size:12px;margin-bottom:5px}
.hub-prog__top b{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hub-prog__top span{color:var(--ui-ink-soft);flex:none}
.hub-prog__bar{height:7px;background:#eef0f3;border-radius:999px;overflow:hidden}
.hub-prog__bar i{display:block;height:100%;background:var(--ui-accent);border-radius:999px}

@media (max-width:760px){.hub-stats{grid-template-columns:repeat(2,1fr)}.hub-cols{grid-template-columns:1fr}}
