/* RiD進捗ポータル — 取引先ダッシュボード（白黒・マットブラック）
   方針：真っ黒#000は使わず #181818 のマットブラック。オフホワイト基調のエディトリアル。 */
:root{
  --ink:#181818; --ink-2:#2b2b2b; --paper:#faf9f7; --card:#ffffff;
  --line:#e7e6e2; --line-2:#efeeea; --sub:#7a7873; --faint:#a8a6a0;
  --track:#ececea; --chip:#f3f2ee;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.rid-portal{
  font-family:-apple-system,"Hiragino Sans","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  background:var(--paper);color:var(--ink);font-feature-settings:"tnum" 1;line-height:1.5;
}
.rid-portal .wrap{max-width:1080px;margin:0 auto;padding:0 28px}

/* ヘッダ（マットブラック帯） */
.rid-portal header.bar{background:var(--ink);color:#fff}
.rid-portal .bar .wrap{display:flex;align-items:center;justify-content:space-between;height:62px}
.rid-portal .brand{display:flex;align-items:baseline;gap:12px}
.rid-portal .brand .logo{font-weight:700;letter-spacing:.28em;font-size:15px}
.rid-portal .brand .sys{font-size:11px;letter-spacing:.22em;color:#b9b8b3;text-transform:uppercase}
.rid-portal .who{text-align:right;display:flex;flex-direction:column;gap:2px;line-height:1.4}
.rid-portal .who .today{font-size:13px;color:#fff;font-weight:600;letter-spacing:.02em}
.rid-portal .who .updated{font-size:11px;color:#cfcdc8}
/* ナビ下のサブバー（クライアント／担当） */
.rid-portal .subbar{background:var(--card);border-bottom:1px solid var(--line)}
.rid-portal .subbar .wrap{display:flex;align-items:center;gap:8px;padding:11px 28px;font-size:12.5px;flex-wrap:wrap}
.rid-portal .subbar .sb-l{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.rid-portal .subbar b{font-weight:600;color:var(--ink)}
.rid-portal .subbar .sb-sep{color:var(--line);margin:0 4px}
.rid-portal .subbar .sb-dep{display:inline-block;font-size:11px;font-weight:600;color:var(--ink);background:var(--chip);border-radius:99px;padding:2px 10px;margin-left:6px}
/* 部署スコープのレポートボタン（サブバー右寄せ＝いま見ている部署のレポートを出す） */
.rid-portal .subbar .sb-reports{margin-left:auto;display:inline-flex;align-items:center;gap:6px}
.rid-portal .sb-rep{font-size:11.5px;font-weight:600;color:var(--ink);background:var(--card);border:1px solid var(--ink);border-radius:99px;padding:4px 13px;text-decoration:none;white-space:nowrap}
.rid-portal .sb-rep:hover{background:var(--ink);color:#fff}
/* 部署タブ（最上段）＝白帯で黒ヘッダから明確に分離。表示タブ（下）と色を分ける。 */
.rid-portal .rid-dept-tabs{background:var(--card);border-bottom:1px solid var(--line)}
.rid-portal .rid-dept-tabs .wrap{display:flex;align-items:center;gap:4px;overflow-x:auto}
.rid-portal .rid-dept{padding:12px 16px;font-size:14px;font-weight:700;color:var(--sub);text-decoration:none;border-bottom:2px solid transparent;white-space:nowrap;letter-spacing:.02em}
.rid-portal .rid-dept:hover{color:var(--ink)}
.rid-portal .rid-dept.active{color:var(--ink);border-bottom-color:var(--ink)}
/* 行頭ラベル（部署／表示）＝どちらの並びか一目で分かるように */
.rid-portal .nav-glabel{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);font-weight:700;margin-right:12px;flex:0 0 auto;white-space:nowrap}
/* 表示タブ（概要/ダッシュボード…）は、部署タブがある時だけ薄グレーにして部署タブと差別化（単一部署のクリエイティブ等は従来の白のまま） */
.rid-portal .rid-dept-tabs + .tabs{background:var(--chip)}
.rid-portal .pcards-kaso{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:820px){.rid-portal .pcards-kaso{grid-template-columns:1fr}}
.rid-portal .pcards-kaso .pph{grid-template-columns:74px 1fr 42px}
.rid-portal .pcard .pbadge.over{background:#c0392b;color:#fff}
.rid-portal .pcard .pbadge.done{background:#2f7d4f;color:#fff}
.rid-portal .pcard .pbadge.hold{background:#b07b2f;color:#fff}
.rid-portal .kaso-hold{margin-top:10px;font-size:11px;color:#8a6d1a;border-left:3px solid #b07b2f;background:#fbf6ec;padding:6px 10px;border-radius:0 4px 4px 0}
.rid-portal .kaso-skill{font-size:10.5px;color:var(--sub);margin-left:6px}
.rid-portal .kaso-new{font-size:10px;color:#7a4ac0;font-weight:600}
.rid-portal .kaso-edit-tbl{border-collapse:collapse;width:100%;max-width:940px;font-size:12.5px;margin:2px 0 6px}
.rid-portal .kaso-edit-tbl th{text-align:left;font-size:10.5px;color:var(--sub);border-bottom:1px solid var(--ink);padding:5px 7px;font-weight:600}
.rid-portal .kaso-edit-tbl td{padding:4px 7px;border-bottom:1px solid var(--line-2)}
.rid-portal .kaso-edit-tbl input{font:inherit;font-size:12px;padding:3px 6px;border:1px solid var(--line);border-radius:5px;background:var(--card)}
.rid-portal .kaso-del{font-size:11px;color:#b3382f;background:none;border:none;cursor:pointer;padding:2px 4px}
.rid-portal .kaso-add{font-size:12px;padding:5px 13px;margin-top:2px}
/* ガント 遅延コメント */
.rid-portal .g-status{font-size:13px;color:var(--sub);margin-bottom:16px;padding:12px 16px;background:var(--card);border:1px solid var(--line);border-radius:2px}
.rid-portal .g-status .mk{font-weight:700;margin-right:5px;color:var(--ink)}
.rid-portal .g-status.alert{border-color:var(--ink);background:#f6f5f2;color:var(--ink);font-weight:600}
.rid-portal .g-status-sub{display:block;font-size:11.5px;color:var(--sub);font-weight:400;margin:4px 0 0 18px}
/* アラートのクリックジャンプ（対象プロジェクト/スポットへ） */
.rid-portal [data-goto],.rid-portal [data-goto-spot]{cursor:pointer}
.rid-portal .ovr[data-goto]:hover,.rid-portal .ovr[data-goto-spot]:hover,
.rid-portal .g-status-sub[data-goto]:hover,.rid-portal .g-status-sub[data-goto-spot]:hover,
.rid-portal .myalert-list li[data-goto]:hover .ma-item,.rid-portal .myalert-list li[data-goto-spot]:hover .ma-item{text-decoration:underline}
.rid-portal .spot-card.hl{outline:2px solid var(--ink);outline-offset:2px;transition:outline-color .3s}

/* タイトル */
.rid-portal .head{padding:46px 0 26px}
.rid-portal .eyebrow{font-size:11px;letter-spacing:.3em;color:var(--faint);text-transform:uppercase;margin-bottom:12px}
.rid-portal .head h1{font-size:30px;font-weight:600;letter-spacing:.02em}
.rid-portal .head .meta{margin-top:10px;font-size:12.5px;color:var(--sub)}

/* 総括ストリップ */
.rid-portal .summary{display:flex;align-items:center;gap:34px;border-top:1px solid var(--ink);
  border-bottom:1px solid var(--line);padding:26px 0;margin-bottom:40px}
.rid-portal .ring{--p:0;--size:104px;width:var(--size);height:var(--size);border-radius:50%;flex:0 0 auto;
  background:conic-gradient(var(--ink) calc(var(--p)*1%), var(--track) 0);display:grid;place-items:center;position:relative}
.rid-portal .ring::before{content:"";position:absolute;inset:11px;border-radius:50%;background:var(--paper)}
.rid-portal .ring .val{position:relative;font-size:24px;font-weight:600}
.rid-portal .ring .val small{font-size:12px;font-weight:500;color:var(--sub)}
.rid-portal .summary .s-meta .l{font-size:11px;letter-spacing:.26em;color:var(--faint);text-transform:uppercase}
.rid-portal .summary .s-meta .big{font-size:18px;font-weight:600;margin-top:6px}
.rid-portal .summary .s-meta .sub{font-size:12.5px;color:var(--sub);margin-top:4px}
.rid-portal .summary .s-meta .ovr{font-size:12.5px;color:var(--ink);margin-top:8px;font-weight:500}
.rid-portal .summary .divider{width:1px;align-self:stretch;background:var(--line)}

/* 案件カード */
.rid-portal .grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.rid-portal .card{background:var(--card);border:1px solid var(--line);padding:24px 24px 22px;position:relative}
.rid-portal .card .top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.rid-portal .tag{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--sub);
  border:1px solid var(--line);padding:3px 9px;border-radius:2px}
.rid-portal .card h2{font-size:17px;font-weight:600;letter-spacing:.01em;margin-top:2px}
.rid-portal .card .pj-meta{font-size:11.5px;color:var(--faint);margin-top:5px}
.rid-portal .card .body{display:flex;gap:22px;margin-top:20px;align-items:center}
.rid-portal .ring-sm{--p:0;--size:74px;width:var(--size);height:var(--size);border-radius:50%;flex:0 0 auto;
  background:conic-gradient(var(--ink) calc(var(--p)*1%), var(--track) 0);display:grid;place-items:center;position:relative}
.rid-portal .ring-sm::before{content:"";position:absolute;inset:9px;border-radius:50%;background:var(--card)}
.rid-portal .ring-sm .val{position:relative;font-size:17px;font-weight:600}
.rid-portal .phases{flex:1;min-width:0}
.rid-portal .ph{display:grid;grid-template-columns:18px 1fr 38px;align-items:center;gap:10px;margin:8px 0}
.rid-portal .ph .k{font-size:11px;font-weight:700;color:var(--ink)}
.rid-portal .ph .barwrap{height:5px;background:var(--track);border-radius:99px;overflow:hidden}
.rid-portal .ph .bar{height:100%;background:var(--ink);border-radius:99px}
.rid-portal .ph .pct{font-size:11.5px;color:var(--sub);text-align:right}
.rid-portal .card .foot{display:flex;justify-content:space-between;align-items:center;
  margin-top:18px;padding-top:14px;border-top:1px solid var(--line-2)}
.rid-portal .chip{font-size:11px;color:var(--ink);background:var(--chip);padding:4px 11px;border-radius:99px}
.rid-portal .chip.dim{color:var(--sub)}
.rid-portal .due{font-size:11.5px;color:var(--sub)}
.rid-portal .due b{color:var(--ink);font-weight:600}

/* 遅延アラート（白黒のまま反転で表現） */
.rid-portal .card.alert{border-color:var(--ink);background:#f6f5f2}
.rid-portal .card.alert::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--ink)}
.rid-portal .chip.alert{background:var(--ink);color:#fff}
.rid-portal .due.over{color:var(--ink);font-weight:600}
.rid-portal .due.over .mk{font-size:9px;margin-right:5px;vertical-align:1px}
.rid-portal .alert-badge{display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:#fff;
  font-size:13px;font-weight:600;padding:5px 12px;border-radius:3px}
.rid-portal .alert-badge .mk{font-size:10px}

/* セクション見出し */
.rid-portal .sec{margin:48px 0 0}
.rid-portal .sec .l{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--faint)}
.rid-portal .sec h2.t{font-size:18px;font-weight:600;margin:8px 0 16px;letter-spacing:.01em}

/* ガントチャート */
.rid-portal .gantt{border:1px solid var(--line);background:var(--card);padding:20px 24px 16px}
.rid-portal .g-axis{position:relative;height:16px;margin-left:32px;margin-bottom:8px}
.rid-portal .g-axis .m{position:absolute;top:0;font-size:10px;color:var(--faint);letter-spacing:.08em}
.rid-portal .g-body{position:relative}
.rid-portal .g-gl{position:absolute;top:0;bottom:0;width:1px;background:var(--line-2)}
.rid-portal .g-today{position:absolute;top:-26px;bottom:0;width:1px;background:var(--ink);z-index:4}
.rid-portal .g-today .lbl{position:absolute;top:0;left:5px;font-size:9px;color:var(--ink);white-space:nowrap}
.rid-portal .g-proj{padding:13px 0;border-bottom:1px solid var(--line-2);position:relative;z-index:2}
.rid-portal .g-proj:last-child{border-bottom:0}
/* 左側ラベル（案件名・A/B/Cキー）は横スクロールに追従（sticky） */
.rid-portal .g-proj .nm{font-size:12.5px;font-weight:600;margin-bottom:9px;
  position:sticky;left:0;display:inline-block;max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  background:var(--card);padding-right:10px;z-index:3}
.rid-portal .g-phase{display:grid;grid-template-columns:24px 1fr;gap:8px;align-items:center;margin:5px 0}
.rid-portal .g-phase .pk{font-size:10px;font-weight:700;color:var(--sub);text-align:center;
  position:sticky;left:0;background:var(--card);z-index:3}
.rid-portal .g-lane{position:relative;height:7px;background:#f1f0ed;border-radius:2px}
.rid-portal .g-bar{position:absolute;top:0;bottom:0;background:#d6d5d0;border-radius:2px}
.rid-portal .g-done{position:absolute;top:0;bottom:0;left:0;background:var(--ink);border-radius:2px}
.rid-portal .g-legend{display:flex;gap:20px;margin-top:14px;font-size:10.5px;color:var(--sub)}
.rid-portal .g-legend i{display:inline-block;width:16px;height:6px;border-radius:2px;vertical-align:1px;margin-right:6px}
/* ガント横スクロール（年度フル表示） */
.rid-portal .g-hint{font-size:10.5px;color:var(--faint);text-align:right;margin-bottom:6px;letter-spacing:.04em}
.rid-portal .g-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
.rid-portal .g-scroll .g-axis,.rid-portal .g-scroll .g-body{min-width:1240px}

/* チェックリスト詳細 */
.rid-portal .detail{border:1px solid var(--line);background:var(--card);padding:22px 24px}
.rid-portal .detail .dh{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--line);padding-bottom:12px}
.rid-portal .detail .dh .nm{font-size:15px;font-weight:600}
.rid-portal .detail .dh .cnt{font-size:11.5px;color:var(--faint)}
.rid-portal .phgrp{margin-top:18px}
.rid-portal .phgrp .ph-t{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);font-weight:700;border-left:3px solid var(--ink);padding-left:9px;margin-bottom:6px}
.rid-portal .catgrp{margin:8px 0 6px 12px}
.rid-portal .catgrp .cat-t{font-size:11.5px;color:var(--sub);margin:10px 0 2px}
.rid-portal .it{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--line-2)}
.rid-portal .it .nm{font-size:12.5px}
.rid-portal .it.todo .nm{color:var(--sub)}
.rid-portal .it .st{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--sub);white-space:nowrap}
.rid-portal .it .dot{width:9px;height:9px;border-radius:50%;border:1px solid var(--ink);flex:0 0 auto;overflow:hidden}
.rid-portal .it .dot.done{background:var(--ink)}
.rid-portal .it .dot.chk{background:linear-gradient(90deg,var(--ink) 75%,transparent 0)}
.rid-portal .it .dot.prog{background:linear-gradient(90deg,var(--ink) 50%,transparent 0)}

.rid-portal footer{border-top:1px solid var(--line);padding:22px 0 50px;color:var(--faint);font-size:11px;letter-spacing:.04em}
.rid-portal footer .foot-row{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.vesper-credit{display:inline-flex;align-items:center;gap:7px;color:var(--faint)}
.vesper-credit .vesper-mark{width:15px;height:15px;flex-shrink:0;opacity:.85}
.vesper-credit .vesper-txt{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase}
.rid-login-page .login-vesper{margin-top:14px;display:flex;justify-content:center}
.rid-login-page .login-vesper .vesper-credit{color:var(--faint)}
.rid-login-page .login-vesper .vesper-mark{width:14px;height:14px}

/* ログイン画面（取引先） */
.rid-portal.rid-login-page{min-height:100vh;display:flex;flex-direction:column}
.rid-login-page .login-wrap{flex:1;display:grid;place-items:center;padding:48px 20px}
.rid-login-page .login-card{width:100%;max-width:380px;background:var(--card);border:1px solid var(--line);padding:42px 36px 38px}
.login-card .login-h{text-align:center;margin-bottom:30px}
.login-card .logo-lg{font-weight:700;letter-spacing:.32em;font-size:24px;color:var(--ink)}
.login-card .login-sub{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--faint);margin-top:9px}
#rid-loginform p{margin:0 0 16px}
#rid-loginform label{display:block;font-size:11px;letter-spacing:.1em;color:var(--sub);margin-bottom:6px}
#rid-loginform input.input,
#rid-loginform input[type=text],
#rid-loginform input[type=password]{width:100%;border:1px solid var(--line);background:#fff;
  padding:11px 12px;font-size:14px;color:var(--ink);border-radius:2px;outline:none;
  font-family:inherit;transition:border-color .15s}
#rid-loginform input.input:focus{border-color:var(--ink)}
#rid-loginform .login-submit{margin-top:6px;margin-bottom:0}
#rid-loginform #wp-submit{width:100%;background:var(--ink);color:#fff;border:0;
  padding:13px;font-size:13px;letter-spacing:.1em;border-radius:2px;cursor:pointer;
  font-family:inherit;transition:background .15s}
#rid-loginform #wp-submit:hover{background:#0e0e0e}

/* ロゴ（アプリアイコン画像＝ドーナツマーク） */
.rid-portal .rid-logo{display:block}
.rid-portal .bar .brand{align-items:center}
.rid-portal .bar .rid-logo{height:30px;width:30px;border-radius:7px}
.rid-login-page .login-h{color:var(--ink)}
.rid-login-page .login-h .rid-logo{width:76px;height:76px;border-radius:18px;margin:0 auto 16px}

/* ヘッダ右側（社名＋ログアウト） */
.rid-portal .bar-right{display:flex;align-items:center;gap:16px}
.rid-portal .bar-right .login-as{font-size:11.5px;color:#b9b8b3;letter-spacing:.02em;white-space:nowrap}
.rid-portal .bar-right .login-as b{color:#fff;font-weight:600}
.rid-portal .bar .logout{display:inline-block;font-size:11px;letter-spacing:.06em;color:#cfcdc8;
  border:1px solid #444;padding:6px 13px;border-radius:2px;text-decoration:none;white-space:nowrap;transition:.15s}
.rid-portal .bar .logout:hover{color:#fff;border-color:#8a8a8a}
.rid-portal .bar .report-btn{display:inline-block;font-size:11px;letter-spacing:.06em;color:#181818;background:#fff;
  border:1px solid #fff;padding:6px 14px;border-radius:2px;text-decoration:none;white-space:nowrap;font-weight:600;transition:.15s}
.rid-portal .bar .report-btn:hover{background:#e9e8e4;border-color:#e9e8e4}

/* ── タブナビ／ビュー切替（v0.006）── */
.rid-portal .tabs{background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.rid-portal .tabs .wrap{display:flex;gap:2px;overflow-x:auto}
.rid-portal .tab{padding:14px 18px;font-size:13px;color:var(--sub);text-decoration:none;border-bottom:2px solid transparent;letter-spacing:.04em;white-space:nowrap}
.rid-portal .tab:hover{color:var(--ink)}
.rid-portal .tab.active{color:var(--ink);font-weight:600;border-bottom-color:var(--ink)}
.rid-portal .tabs .tab:first-child{padding-left:0} /* 先頭タブをロゴ・クライアント・本文の左端に揃える */
.rid-portal .view{display:none}
.rid-portal .view.active{display:block}

/* 概要：案件クイックリスト */
.rid-portal .qlist{border-top:1px solid var(--line)}
.rid-portal .qrow{display:grid;grid-template-columns:1fr 84px 150px 42px 60px;align-items:center;gap:14px;padding:13px 4px;border-bottom:1px solid var(--line-2);text-decoration:none;color:var(--ink)}
.rid-portal .qrow:hover{background:#f6f5f2}
/* スポット依頼の行（クイックリスト・カテゴリ列の色だけ変える） */
.rid-portal .qrow.qrow-spot .qcat{color:#7a4a25}
.rid-portal .qrow .qn{font-size:13.5px;font-weight:500}
.rid-portal .qrow .qcat{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.rid-portal .qrow .qbarwrap{height:5px;background:var(--track);border-radius:99px;overflow:hidden}
.rid-portal .qrow .qbar{height:100%;background:var(--ink);border-radius:99px}
.rid-portal .qrow.alert .qbar{background:var(--ink)}
.rid-portal .qrow .qpct{font-size:12px;color:var(--sub);text-align:right}
.rid-portal .qrow .qst{font-size:11px;color:var(--sub);text-align:right}
.rid-portal .qrow .qst.over{color:var(--ink);font-weight:600}

/* ダッシュボード */
.rid-portal .dash-top{display:flex;align-items:center;gap:30px;border-top:1px solid var(--ink);border-bottom:1px solid var(--line);padding:24px 0;margin-bottom:8px}
.rid-portal .gtabs{display:flex;gap:6px;margin:4px 0 16px;flex-wrap:wrap}
.rid-portal .gtab{background:var(--chip);border:1px solid transparent;color:var(--sub);border-radius:99px;padding:5px 16px;font-size:12px;cursor:pointer;font-family:inherit}
.rid-portal .gtab.active{background:var(--ink);color:#fff}
.rid-portal .gpane{display:none}
.rid-portal .gpane.active{display:block}
.rid-portal .qtr-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.rid-portal .qtr{border:1px solid var(--line);background:var(--card);padding:16px}
.rid-portal .qtr-h{font-size:12px;color:var(--sub)} .rid-portal .qtr-h b{font-size:14px;color:var(--ink);margin-right:6px}
.rid-portal .qtr-barwrap{height:6px;background:var(--track);border-radius:99px;overflow:hidden;margin:12px 0 8px}
.rid-portal .qtr-bar{height:100%;background:var(--ink);border-radius:99px}
.rid-portal .qtr-meta{display:flex;justify-content:space-between;font-size:11.5px;color:var(--sub)}
.rid-portal .qtr-meta span:first-child{font-weight:600;color:var(--ink)}
.rid-portal .kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.rid-portal .kpi{border:1px solid var(--line);background:var(--card);padding:15px 18px}
.rid-portal .kpi .kv{font-size:26px;font-weight:600}
.rid-portal .kpi .kl{font-size:11px;color:var(--sub);margin-top:4px;letter-spacing:.04em}
.rid-portal .kpi.bad{border-color:var(--ink)} .rid-portal .kpi.dim .kv{color:var(--faint)}

/* 予定vs実績 推移 */
.rid-portal .trend{border:1px solid var(--line);background:var(--card);padding:18px 20px 14px}
.rid-portal .trend-svg{width:100%;height:auto;display:block}
.rid-portal .t-axis{stroke:var(--line);stroke-width:1}
.rid-portal .t-grid{stroke:var(--line-2);stroke-width:1}
.rid-portal .t-plan{fill:none;stroke:#b9b8b3;stroke-width:2;vector-effect:non-scaling-stroke}
.rid-portal .t-now{stroke:var(--ink);stroke-width:1;vector-effect:non-scaling-stroke}
.rid-portal .t-actual{fill:var(--ink)}
.rid-portal .tr-wrap{position:relative}
.rid-portal .tr-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
.rid-portal .tr-yaxis{position:absolute;left:0;top:0;height:212px;width:36px;pointer-events:none}
.rid-portal .tr-yaxis span{position:absolute;left:0;font-size:9px;color:#a8a6a0;background:rgba(250,249,247,.92);padding:0 4px;border-radius:4px}
.rid-portal .trend-x{display:flex;justify-content:space-between;margin-top:6px;font-size:9.5px;color:var(--faint)}
.rid-portal .trend-legend{display:flex;gap:18px;margin-top:12px;font-size:10.5px;color:var(--sub)}
.rid-portal .trend-legend i{display:inline-block;width:16px;height:0;vertical-align:3px;margin-right:6px;border-top:2px solid #b9b8b3}
.rid-portal .trend-legend .li-actual{border:0;width:9px;height:9px;border-radius:50%;background:var(--ink);vertical-align:0}

/* 案件カードのチェックリスト詳細トグル */
.rid-portal .detail-toggle{margin-top:14px;width:100%;background:none;border:1px solid var(--line);color:var(--sub);font-size:11.5px;padding:8px;border-radius:2px;cursor:pointer;font-family:inherit;letter-spacing:.04em}
.rid-portal .detail-toggle:hover{border-color:var(--ink);color:var(--ink)}
.rid-portal .detail-panel{display:none;margin-top:12px}
.rid-portal .detail-panel.open{display:block}
.rid-portal .detail-panel .detail{border:0;padding:0}

/* ── v0.007 ── */
/* 案件一覧：1案件フル幅（1列） */
.rid-portal .view[data-view="projects"] .grid{grid-template-columns:1fr}
/* 概要：一言サマリ */
.rid-portal .phrase{display:flex;align-items:center;gap:18px;background:var(--ink);color:#fff;padding:16px 22px;margin:6px 0 30px;border-radius:3px}
.rid-portal .phrase .phrase-l{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#b9b8b3;white-space:nowrap}
.rid-portal .phrase .phrase-t{font-size:15px;font-weight:600;flex:1;letter-spacing:.02em}
.rid-portal .phrase .phrase-p{font-size:21px;font-weight:600}
/* 前週・前期・前年度 比較 */
.rid-portal .cmp{display:flex;border:1px solid var(--line);background:var(--card);margin:0 0 30px}
.rid-portal .cmp-item{flex:1;padding:15px 20px;border-right:1px solid var(--line-2);display:flex;flex-direction:column;gap:6px}
.rid-portal .cmp-item:last-child{border-right:0}
.rid-portal .cmp-l{font-size:11px;letter-spacing:.1em;color:var(--faint)}
.rid-portal .cmp-v{font-size:20px;font-weight:600;color:var(--ink)}
.rid-portal .cmp-v.none{color:var(--faint);font-weight:400}
.rid-portal .cmp-v.up::before{content:'▲ ';font-size:11px;vertical-align:1px}
.rid-portal .cmp-v.down::before{content:'▼ ';font-size:11px;vertical-align:1px}

/* アニメーション（読み込み時の伸び）。バーは width をトランジション、ドーナツ/数値はJSで
   ※ ご要望により reduced-motion 環境でも動かす（@media gate は外している） */
.rid-portal .ph .bar,.rid-portal .qrow .qbar,.rid-portal .qtr-bar,.rid-portal .g-done{transition:width .85s cubic-bezier(.22,1,.36,1)}
/* qlist バー（黒塗り明確化）。span要素なので display:block を明示（幅が効くように） */
.rid-portal .qrow .qbarwrap{height:6px;display:block}
.rid-portal .qrow .qbar{background:var(--ink);display:block;height:100%}
/* 詳細項目：担当者名 */
.rid-portal .it-right{display:flex;align-items:center;gap:14px;justify-content:flex-end}
.rid-portal .it-tan{font-size:10.5px;color:var(--sub);background:var(--chip);padding:2px 9px;border-radius:99px;white-space:nowrap}
.rid-portal .it-due{font-size:10.5px;color:var(--sub);white-space:nowrap;letter-spacing:.02em}
/* 詳細：閉じるボタン */
.rid-portal .detail-close{margin-left:auto;background:none;border:1px solid var(--line);color:var(--sub);font-size:11px;padding:5px 12px;border-radius:2px;cursor:pointer;font-family:inherit;white-space:nowrap}
.rid-portal .detail-close:hover{border-color:var(--ink);color:var(--ink)}
.rid-portal .detail-close-bottom{margin:16px 0 2px;width:100%}

/* 計画方針タブ（v0.008） */
.rid-portal .plan-tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line)}
.rid-portal .plan-tbl th,.rid-portal .plan-tbl td{padding:11px 14px;font-size:12.5px;border-bottom:1px solid var(--line-2);text-align:left;vertical-align:top;line-height:1.6}
.rid-portal .plan-tbl tr:last-child th,.rid-portal .plan-tbl tr:last-child td{border-bottom:0}
.rid-portal .plan-tbl th{font-weight:600;color:var(--ink);width:210px;background:#f8f7f4}
.rid-portal .plan-tbl td{color:var(--sub)}
.rid-portal .plan-tbl.cap th,.rid-portal .plan-tbl.cap td{width:auto;white-space:nowrap;text-align:right}
.rid-portal .plan-tbl.cap th:first-child,.rid-portal .plan-tbl.cap td:first-child{text-align:left}
.rid-portal .plan-tbl.cap .caphead th{background:var(--ink);color:#fff;font-weight:600}
.rid-portal .plan-tbl.cap td:first-child{font-weight:600;color:var(--ink);background:#f8f7f4}
/* ガント：遅延強調 */
.rid-portal .g-bar.over{outline:1.5px solid var(--ink);outline-offset:1px}
.rid-portal .g-phase .pk.over{color:var(--ink);font-weight:800}
.rid-portal .g-proj.over .nm{color:var(--ink)}
.rid-portal .g-over-mk{font-size:9px;vertical-align:1px}
.rid-portal .g-over-tag{font-size:9.5px;background:var(--ink);color:#fff;padding:1px 8px;border-radius:99px;letter-spacing:.04em;margin-left:4px;font-weight:600}

/* ヘッダ：共有フォルダリンク */
.rid-portal .bar .shared-link{display:inline-flex;align-items:center;gap:5px;font-size:11px;letter-spacing:.04em;color:#cfcdc8;text-decoration:none;border:1px solid #4a4a4a;border-radius:99px;padding:5px 12px;transition:.15s}
.rid-portal .bar .shared-link:hover{color:#fff;border-color:#8a8a8a}
.rid-portal .bar .shared-link .ic{font-size:12px;filter:grayscale(1) brightness(1.6)}

/* 基本情報 */
.rid-portal .info-actions{display:flex;align-items:center;gap:14px;margin:-6px 0 18px}
.rid-portal .info-edit-btn{background:var(--ink);color:#fff;border:0;border-radius:99px;padding:7px 20px;font-size:12px;cursor:pointer;font-family:inherit;letter-spacing:.04em}
.rid-portal .info-edit-btn:hover{background:#000}
.rid-portal .info-saved{font-size:12px;color:#2e7d32}
.rid-portal .info-tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line)}
.rid-portal .info-tbl th,.rid-portal .info-tbl td{padding:11px 14px;font-size:12.5px;border-bottom:1px solid var(--line-2);text-align:left;vertical-align:top;line-height:1.6}
.rid-portal .info-tbl tr:last-child th,.rid-portal .info-tbl tr:last-child td{border-bottom:0}
.rid-portal .info-tbl th{font-weight:600;color:var(--ink);width:210px;background:#f8f7f4}
.rid-portal .info-tbl td{color:var(--sub);word-break:break-all}
.rid-portal .info-tbl td a{color:var(--ink-2)}
/* 基本情報：編集フォーム */
.rid-portal .info-input{font-family:inherit;font-size:13px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:7px;padding:9px 12px;width:100%;max-width:420px}
.rid-portal .info-input:focus{outline:none;border-color:var(--ink)}
.rid-portal .info-hint{font-size:11.5px;color:var(--faint);margin-top:8px}
.rid-portal .info-rows{display:flex;flex-direction:column;gap:8px;max-width:600px}
.rid-portal .info-row{display:grid;grid-template-columns:210px 1fr 32px;gap:8px;align-items:center}
.rid-portal .info-row input{font-family:inherit;font-size:12.5px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:7px;padding:8px 11px}
.rid-portal .info-row input:focus{outline:none;border-color:var(--ink)}
.rid-portal .ir-del{background:transparent;border:1px solid var(--line);border-radius:7px;color:var(--faint);font-size:12px;cursor:pointer;height:34px}
.rid-portal .ir-del:hover{color:var(--ink);border-color:var(--ink)}
.rid-portal .ir-add{margin-top:12px;background:transparent;border:1px dashed var(--line);border-radius:8px;color:var(--sub);font-size:12px;padding:8px 16px;cursor:pointer;font-family:inherit}
.rid-portal .ir-add:hover{border-color:var(--ink);color:var(--ink)}
.rid-portal .info-form-actions{display:flex;gap:10px;margin-top:26px}
.rid-portal .info-save{background:var(--ink);color:#fff;border:0;border-radius:99px;padding:9px 26px;font-size:12.5px;cursor:pointer;font-family:inherit;letter-spacing:.04em}
.rid-portal .info-save:hover{background:#000}
.rid-portal .info-save:disabled{opacity:.5;cursor:default}
.rid-portal .info-cancel{background:transparent;color:var(--sub);border:1px solid var(--line);border-radius:99px;padding:9px 22px;font-size:12.5px;cursor:pointer;font-family:inherit}
.rid-portal .info-cancel:hover{border-color:var(--ink);color:var(--ink)}

/* 承認制：取引先の進捗変更「提案」 */
.rid-portal .prop-note{font-size:11.5px;color:var(--sub);background:#f4f6fb;border:1px solid #e3e8f3;border-radius:7px;padding:9px 12px;margin:4px 0 14px;line-height:1.6}
.rid-portal .prop-note b{color:#1f3a8a}
.rid-portal .it.editable{align-items:center}
.rid-portal .it .it-stat,.rid-portal .it .tan-sel{font-family:inherit;font-size:11.5px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:6px;padding:3px 6px;cursor:pointer}
.rid-portal .it .tan-sel{color:var(--sub);max-width:130px}
.rid-portal .it-add .it-add-tan{font-family:inherit;font-size:11.5px;color:var(--sub);background:#fff;border:1px solid var(--line);border-radius:7px;padding:6px;max-width:150px}
.rid-portal .it .it-stat:focus{outline:none;border-color:var(--ink)}
.rid-portal .it .it-del{background:none;border:none;color:var(--faint);cursor:pointer;font-size:11px;line-height:1;padding:2px 5px;border-radius:5px;margin-left:2px}
.rid-portal .it .it-del:hover{color:#c0392b;background:#faecec}
.rid-portal .it.proposed-del .nm{text-decoration:line-through;color:var(--faint)}
.rid-portal .prop-tag{font-size:9.5px;letter-spacing:.04em;background:#fdfaf2;color:#7d5a14;border:1px solid #e3d9c2;border-radius:99px;padding:1px 8px;margin-left:6px;white-space:nowrap}
.rid-portal .it.proposed-del .prop-tag{background:#fbeeec;color:#c0392b;border-color:#e6c9c9}
.rid-portal .prop-tag.mine{cursor:pointer}
.rid-portal .prop-tag.mine:hover{border-color:#7d5a14;background:#faf3e3}
.rid-portal .ip-panel{margin:8px 0 4px}
.rid-portal .it.pend-add{opacity:.8}
.rid-portal .it.pend-add .nm{color:var(--sub)}
.rid-portal .it-add{display:flex;gap:8px;align-items:center;margin:8px 0 2px;padding-left:2px}
.rid-portal .it-add-in{flex:1;font-family:inherit;font-size:12px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:7px;padding:7px 10px}
.rid-portal .it-add-in:focus{outline:none;border-color:var(--ink)}
.rid-portal .it-add-go{background:transparent;border:1px dashed var(--line);border-radius:7px;color:var(--sub);font-size:12px;padding:7px 14px;cursor:pointer;font-family:inherit;white-space:nowrap}
.rid-portal .it-add-go:hover{border-color:var(--ink);color:var(--ink)}
.rid-portal .ptoast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:12.5px;padding:10px 20px;border-radius:99px;opacity:0;transition:opacity .2s;pointer-events:none;z-index:60}
.rid-portal .ptoast.show{opacity:1}
.rid-portal .ptoast.bad{background:#c0392b}

/* 自分の担当タスクの期限アラート */
.rid-portal .newtask{border:1px solid var(--ink);background:#fff;border-radius:10px;padding:14px 16px;margin:0 0 18px}
.rid-portal .newtask-h{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:10px}
.rid-portal .newtask-h .mk{font-size:12px;margin-right:2px}
.rid-portal .newtask-list{list-style:none;margin:0;padding:0;display:grid;gap:7px}
.rid-portal .newtask-list li{display:flex;gap:10px;align-items:center;justify-content:space-between;font-size:12.5px;color:var(--ink);cursor:pointer}
.rid-portal .newtask-list li:hover .nt-item{text-decoration:underline}
.rid-portal .newtask-list .nt-st{font-size:10.5px;color:var(--sub);background:var(--chip);padding:2px 9px;border-radius:99px;white-space:nowrap}
.rid-portal .newtask-ok{margin-top:12px;font-family:inherit;font-size:11.5px;border:1px solid var(--line);background:var(--ink);color:#fff;border-radius:8px;padding:7px 14px;cursor:pointer}
.rid-portal .newtask-ok:hover{opacity:.85}
.rid-portal .newtask-ok:disabled{opacity:.5;cursor:default}
.rid-portal .myalert{border:1px solid #e6c9c9;background:#fdf3f3;border-radius:10px;padding:14px 16px;margin:0 0 18px}
.rid-portal .myalert-h{font-size:13px;font-weight:600;color:#a4302a;margin-bottom:10px;position:relative;padding-right:26px}
.rid-portal .myalert-h .mk{font-size:11px}
.rid-portal .myalert-close{position:absolute;top:-3px;right:0;width:22px;height:22px;line-height:20px;text-align:center;font-size:12px;color:#a4302a;background:none;border:1px solid #e6c9c9;border-radius:6px;cursor:pointer;font-family:inherit;padding:0}
.rid-portal .myalert-close:hover{background:#a4302a;color:#fff;border-color:#a4302a}
.rid-portal .myalert-list{list-style:none;margin:0;padding:0;display:grid;gap:7px}
.rid-portal .myalert-list li{display:grid;grid-template-columns:64px 44px 1fr auto;gap:10px;align-items:center;font-size:12.5px;color:var(--ink)}
.rid-portal .myalert-list .ma-tan{font-style:normal;font-size:11px;color:var(--sub);margin-left:8px;white-space:nowrap}
.rid-portal .myalert-list .ma-tag{font-size:10px;text-align:center;border-radius:99px;padding:2px 0;color:#fff;background:#c0392b}
.rid-portal .myalert-list li.near .ma-tag{background:#b8860b}
.rid-portal .myalert-list .ma-due{font-size:12px;color:var(--sub);font-weight:600}
.rid-portal .myalert-list .ma-item{color:var(--ink)}
.rid-portal .myalert-list .ma-st{font-size:11px;color:var(--sub)}

/* チェックリスト詳細の A/B/C/提供物 タブ（アプリ準拠の下線タブ） */
.rid-portal .cl-tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:14px 0 0;flex-wrap:wrap}
.rid-portal .cl-tab{background:none;border:none;border-bottom:2px solid transparent;padding:9px 16px;font-size:12.5px;color:var(--sub);cursor:pointer;font-family:inherit}
.rid-portal .cl-tab:hover{color:var(--ink)}
.rid-portal .cl-tab.active{color:var(--ink);border-bottom-color:var(--ink);font-weight:600}
.rid-portal .cl-pane{display:none;padding-top:10px}
.rid-portal .cl-pane.active{display:block}

/* ミニマルな単色ラインアイコン（絵文字置換・currentColor追従） */
.rid-portal .ic-svg{width:13px;height:13px;display:inline-block;vertical-align:-2px;flex-shrink:0}
.rid-portal .pj-master button .ic-svg{margin-right:5px}

/* 明るい背景用のリンクボタン（スポット共有フォルダ・案件リンク：テスト/本番/データ） */
.rid-portal .folder-link{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:99px;padding:7px 14px;text-decoration:none;transition:.15s}
.rid-portal .folder-link:hover{border-color:var(--ink);background:#fcfbf9}
.rid-portal .folder-link .ic{font-size:12.5px}
.rid-portal .pj-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.rid-portal .pj-links .folder-link{font-size:11.5px;padding:6px 12px}

/* スポット依頼：承認前リスト（マネージャー承認） */
.rid-portal .spot-req-n{font-size:11px;color:#fff;background:#c0392b;border-radius:99px;padding:1px 9px;margin-left:6px;vertical-align:2px}
.rid-portal .spreq-list{display:grid;gap:12px;margin-top:6px}
.rid-portal .spreq{border:1px solid #e3e8f3;background:#f7f9fd;border-radius:9px;padding:13px 15px}
.rid-portal .spreq-h{display:flex;justify-content:space-between;align-items:center;gap:10px}
.rid-portal .spreq-name{font-size:14px;font-weight:600;color:var(--ink)}
.rid-portal .spreq-act{display:flex;gap:8px;flex-shrink:0}
.rid-portal .spreq-ok{background:#1f3a8a;color:#fff;border:0;border-radius:99px;padding:6px 18px;font-size:12px;cursor:pointer;font-family:inherit}
.rid-portal .spreq-ok:hover{background:#16306f}
.rid-portal .spreq-ng{background:transparent;color:var(--sub);border:1px solid var(--line);border-radius:99px;padding:6px 14px;font-size:12px;cursor:pointer;font-family:inherit}
.rid-portal .spreq-ng:hover{border-color:#c0392b;color:#c0392b}
.rid-portal .spreq-act button:disabled{opacity:.5;cursor:default}
.rid-portal .spreq{background:#fff;border:1px solid var(--line)}
.rid-portal .spreq-gates{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:11px;padding-top:11px;border-top:1px solid var(--line-2)}
.rid-portal .spreq-gate{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;border-radius:99px;padding:4px 12px}
.rid-portal .spreq-gate .g-mk{font-weight:700}
.rid-portal .spreq-gate i{font-style:normal;color:var(--faint);font-size:10.5px}
.rid-portal .spreq-gate.wait{background:var(--chip);color:var(--sub)}
.rid-portal .spreq-gate.done{background:#eef4ee;color:#3a6b3a}
.rid-portal .spreq-gate.done i{color:#6a8a6a}
.rid-portal .spreq-gates .spreq-act{margin-left:auto}
.rid-portal .spreq-go{background:var(--ink);color:#fff;border:0;border-radius:99px;padding:6px 16px;font-size:12px;cursor:pointer;font-family:inherit}
.rid-portal .spreq-go:hover{opacity:.85}
.rid-portal .spreq-wait{font-size:11px;color:#1f3a8a;background:#eef1f9;border-radius:99px;padding:3px 11px;white-space:nowrap}
.rid-portal .spreq-meta{font-size:11.5px;color:var(--sub);margin-top:7px}
.rid-portal .spreq-meta b{color:var(--ink)}
.rid-portal .spreq-body{font-size:12px;color:var(--sub);margin-top:7px;line-height:1.7;white-space:pre-line;border-top:1px dashed #dde3f0;padding-top:8px}

/* スポット依頼 */
.rid-portal .g-spot-tag{font-size:9.5px;background:#1f3a8a;color:#fff;padding:1px 8px;border-radius:99px;letter-spacing:.04em;margin-left:4px;font-weight:600}
.rid-portal .spot-req .spot-name{width:100%;max-width:460px;font-family:inherit;font-size:13px;border:1px solid var(--line);border-radius:7px;padding:9px 12px;margin-bottom:10px}
.rid-portal .spot-req .spot-requester{display:block;width:100%;max-width:280px;font-family:inherit;font-size:13px;border:1px solid var(--line);border-radius:7px;padding:9px 12px;margin-bottom:10px}
.rid-portal .spot-req .spot-req-text{display:block;width:100%;max-width:560px;font-family:inherit;font-size:13px;border:1px solid var(--line);border-radius:7px;padding:9px 12px;margin-bottom:10px}
.rid-portal .spot-req .spot-name:focus,.rid-portal .spot-req .spot-requester:focus,.rid-portal .spot-req .spot-req-text:focus,.rid-portal .spot-req .spot-due:focus{outline:none;border-color:var(--ink)}
.rid-portal .spot-req .spot-due-l{display:block;font-size:11.5px;color:var(--sub);margin-bottom:20px}
.rid-portal .spot-req .spot-send-row{margin-bottom:14px}
.rid-portal .spot-send-note{margin-top:0;line-height:1.7;font-size:11.5px;color:var(--sub)}
.rid-portal .spot-req .spot-due{font-family:inherit;font-size:12.5px;border:1px solid var(--line);border-radius:7px;padding:6px 10px}
.rid-portal .spot-req .spot-send{background:var(--ink);color:#fff;border:0;border-radius:99px;padding:9px 24px;font-size:12.5px;cursor:pointer;font-family:inherit;letter-spacing:.04em}
.rid-portal .spot-req .spot-send:hover{background:#000}
.rid-portal .spot-req .spot-send:disabled{opacity:.5;cursor:default}
.rid-portal .spot-folder{margin-bottom:14px}
.rid-portal .spot-list{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.rid-portal .spot-card{background:var(--card);border:1px solid var(--line);border-radius:4px;padding:18px 20px}
.rid-portal .spot-card.alert{border-color:var(--ink)}
.rid-portal .spot-ch{display:flex;justify-content:space-between;align-items:center;gap:10px}
.rid-portal .spot-name-t{font-size:15px;font-weight:600;color:var(--ink)}
.rid-portal .spot-badge{font-size:10px;padding:2px 10px;border-radius:99px;background:var(--ink);color:#fff;white-space:nowrap}
.rid-portal .spot-badge.un{background:#fbeec9;color:#8a6d1a}
.rid-portal .spot-meta{font-size:11.5px;color:var(--sub);margin-top:7px}
.rid-portal .spot-meta b{color:var(--ink)}
.rid-portal .spot-items{list-style:none;margin:6px 0 0;padding:0;display:grid;gap:4px}
.rid-portal .spot-items li{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--sub)}
.rid-portal .spot-items .si-nm{flex:1}
.rid-portal .spot-items .si-st{font-size:11px;color:var(--faint)}
.rid-portal .spot-items li.done .si-nm{color:var(--ink)}

/* マスターのプロジェクト操作（アーカイブ/削除を提案） */
.rid-portal .pj-master{display:flex;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line-2)}
.rid-portal .pj-master button{background:transparent;border:1px solid var(--line);border-radius:7px;color:var(--sub);font-size:11.5px;padding:6px 12px;cursor:pointer;font-family:inherit}
.rid-portal .pj-master .pj-arch:hover{border-color:var(--ink);color:var(--ink)}
.rid-portal .pj-master .pj-trash:hover{border-color:#c0392b;color:#c0392b}
.rid-portal .pj-master button:disabled{opacity:.6;cursor:default;border-style:dashed}

/* 管理者の企業切替 */
.rid-portal .subbar .admin-switch{font-family:inherit;font-size:13px;font-weight:600;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:7px;padding:4px 10px;cursor:pointer}
.rid-portal .subbar .admin-switch:focus{outline:none;border-color:var(--ink)}
.rid-portal .subbar .sb-admin{font-size:10.5px;letter-spacing:.06em;color:#1f3a8a;background:#eef1f9;border-radius:99px;padding:2px 10px;margin-left:10px}
/* デモ取引先（他社デモンストレーション用・実データと分離） */
.rid-portal .subbar .sb-demo{font-size:10.5px;font-weight:700;letter-spacing:.08em;color:#fff;background:var(--ink);border-radius:99px;padding:2px 10px;margin-left:6px}
.rid-portal .subbar .sb-demobtn{margin-left:auto;font-family:inherit;font-size:12px;font-weight:600;color:var(--ink);background:var(--card);border:1px dashed var(--line);border-radius:7px;padding:4px 12px;cursor:pointer;transition:border-color .15s,background .15s}
.rid-portal .subbar .sb-demobtn:hover{border-color:var(--ink);border-style:solid}
.rid-portal .subbar .sb-demobtn:disabled{opacity:.55;cursor:default}

/* 担当者で見る（ダッシュボード） */
.rid-portal .asgn-sel,.rid-portal .it-filter{font-family:inherit;font-size:12.5px;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:7px;padding:6px 11px;cursor:pointer}
.rid-portal .asgn-sel:focus,.rid-portal .it-filter:focus{outline:none;border-color:var(--ink)}
.rid-portal .it-filter{font-size:11.5px;padding:4px 8px;margin-left:auto;margin-right:10px}
.rid-portal .asgn-sum{font-size:12px;color:var(--sub);margin:14px 0 8px}
.rid-portal .asgn-sum b{color:var(--ink);font-weight:600}
/* 担当者別 進捗率 */
.rid-portal .tplist{border:1px solid var(--line);background:var(--card);border-radius:8px;overflow:hidden}
.rid-portal .tplist .tp-row{display:grid;grid-template-columns:1fr 140px 96px;gap:14px;align-items:center;padding:11px 16px;border-bottom:1px solid var(--line-2)}
.rid-portal .tplist .tp-row:last-child{border-bottom:none}
.rid-portal .tplist .tp-row.me{background:#f6faf8}
.rid-portal .tplist .tp-n{font-size:13px;font-weight:600}
.rid-portal .tplist .tp-bar{height:6px;background:var(--track);border-radius:99px;overflow:hidden}
.rid-portal .tplist .tp-i{display:block;height:100%;background:var(--ink);border-radius:99px;transition:width .85s cubic-bezier(.22,1,.36,1)}
.rid-portal .tplist .tp-pc{font-size:12.5px;color:var(--ink);text-align:right;font-weight:600}
.rid-portal .tplist .tp-pc .tp-c{color:var(--sub);font-weight:400;font-size:11px}
.rid-portal .asgn-tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line)}
.rid-portal .asgn-tbl td{padding:9px 12px;font-size:12.5px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.rid-portal .asgn-tbl tr:last-child td{border-bottom:0}
.rid-portal .asgn-tbl .ap{font-weight:600;color:var(--ink);width:34%}
.rid-portal .asgn-tbl .aph{width:34px;color:var(--sub)}
.rid-portal .asgn-tbl .ai{color:var(--sub)}
.rid-portal .asgn-tbl .ast{width:96px;text-align:right;white-space:nowrap;color:var(--ink)}
.rid-portal .asgn-tbl .ast .dot{display:inline-block;width:7px;height:7px;border-radius:99px;background:var(--track);margin-right:5px;vertical-align:1px}
.rid-portal .asgn-tbl .ast .dot.done{background:var(--ink)}
.rid-portal .asgn-tbl .ast .dot.prog{background:var(--sub)}
.rid-portal .asgn-tbl .ast .dot.chk{background:#1f3a8a}

/* プロジェクト一覧（アプリ RiD_PMP 準拠：カテゴリサブタブ＋進行中グループ＋コンパクトカード） */
.rid-portal .psub{display:flex;gap:6px;margin:4px 0 16px;flex-wrap:wrap}
.rid-portal .psub-b{background:var(--chip);border:1px solid transparent;color:var(--sub);border-radius:99px;padding:5px 16px;font-size:12px;cursor:pointer;font-family:inherit}
.rid-portal .psub-b.active{background:var(--ink);color:#fff}
.rid-portal .psub-b .n{opacity:.6;margin-left:5px;font-size:11px}
.rid-portal .ppane{display:none}
.rid-portal .ppane.active{display:block}
.rid-portal .grouphdr{display:flex;align-items:center;gap:9px;margin:16px 0 10px}
.rid-portal .grouphdr .gc{display:none;font-size:12.5px;font-weight:700;color:var(--ink);letter-spacing:.04em;margin-right:2px}
.rid-portal section[data-view=projects].allmode .grouphdr .gc{display:inline-block}
.rid-portal section[data-view=projects].allmode .ppane+.ppane{margin-top:26px}
.rid-portal .grouphdr .gl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint)}
.rid-portal .grouphdr .gn{font-size:11px;color:var(--sub);background:var(--chip);border-radius:99px;padding:1px 9px}
/* 未確定フィルタ：確定カードを隠し、未確定（未着手プール）だけを表示。進捗集計には含めない別枠 */
.rid-portal .psub-b.psub-un{border-color:#ddd9d2}
.rid-portal .psub-b.psub-un.active{background:#8a6d3b;border-color:#8a6d3b;color:#fff}
.rid-portal section[data-view=projects].unmode .ppane .pcard[data-conf="1"]{display:none}
.rid-portal section[data-view=projects].unmode .grouphdr .gl,
.rid-portal section[data-view=projects].unmode .grouphdr .gn{display:none}
.rid-portal .pcard .pbadge{position:absolute;top:16px;right:18px;font-size:10.5px;padding:3px 11px;border-radius:99px;background:var(--ink);color:#fff;letter-spacing:.04em}
.rid-portal .pcard .pbadge.un{background:#fff;color:var(--sub);border:1px solid var(--line)}
/* チェックリスト内のフェーズ/項目アラート */
.rid-portal .cl-tab .ph-flag{margin-left:4px}
.rid-portal .pane-al{font-size:11.5px;padding:7px 12px;margin:2px 0 10px;border-left:3px solid #b7791f;background:#fbf6ec;color:#6b5512;border-radius:0 4px 4px 0}
.rid-portal .pane-al.over{border-color:#b3382f;background:#fbeeec;color:#8f2c24}
.rid-portal .it-flag{font-size:9.5px;font-weight:700;white-space:nowrap;padding:2px 7px;border-radius:99px}
.rid-portal .it-flag.over{background:#fbeeec;color:#b3382f}
.rid-portal .it-flag.near{background:#fbf6ec;color:#8a6d1a}
/* 担当者で見る → 項目ジャンプ（下線は付けない） */
.rid-portal .asgn-go{cursor:pointer}
.rid-portal .asgn-go:hover td{background:#f6f5f2}
/* 提供物 → 該当プロジェクトの提供物タブへ（下線は付けない） */
.rid-portal .supply .row[data-goto-supply]{cursor:pointer;border-radius:6px;padding:4px 6px;margin:-4px -6px}
.rid-portal .supply .row[data-goto-supply]:hover{background:#f6f5f2}
.rid-portal .it.hl{outline:2px solid var(--ink);outline-offset:1px;border-radius:4px;transition:outline-color .3s}
.rid-portal .pcard .ptag{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--sub);padding-right:64px}
.rid-portal .pcard .pname{margin:5px 0 2px;font-size:16px;font-weight:600;color:var(--ink)}
.rid-portal .pcard .pmeta{font-size:11.5px;color:var(--faint)}
.rid-portal .pcard .pmeta b{color:var(--ink);font-weight:600}
.rid-portal .pcard .pmeta .ov{color:#c0392b}
/* A/B/C 各フェーズの期限（カードに3つとも表示） */
.rid-portal .pcard .pmeta .pdues{display:inline-flex;gap:6px;margin-left:9px;flex-wrap:wrap;vertical-align:middle}
.rid-portal .pcard .pmeta .pdue{font-size:10.5px;color:var(--sub);background:var(--chip);border-radius:99px;padding:1px 8px;white-space:nowrap}
.rid-portal .pcard .pmeta .pdue.done{color:#3a6b3a;background:#eef4ee}
.rid-portal .pcard .pmeta .pdue.over{color:#c0392b;background:#fbeeec}
.rid-portal .pcard .pphases{margin-top:12px}
.rid-portal .pcard .pph{display:grid;grid-template-columns:64px 1fr 42px;gap:9px;align-items:center;margin-top:9px}
.rid-portal .pcard .pph .k{font-size:11px;font-weight:700;white-space:nowrap}
.rid-portal .pcard .pph .barwrap{height:5px;background:var(--track);border-radius:99px;overflow:hidden}
.rid-portal .pcard .pph .bar{height:100%;background:var(--ink);border-radius:99px}
.rid-portal .pcard .pph .pct{font-size:11.5px;color:var(--sub);text-align:right}
/* フェーズ別の遅延・期限間近（A/B/Cのどこが遅れているか） */
.rid-portal .pcard .pph .bar.over{background:#b3382f}
.rid-portal .pcard .pph .bar.near{background:#b7791f}
.rid-portal .ph-flag{display:inline-block;margin-left:5px;font-size:9px;font-weight:700;font-style:normal;letter-spacing:0}
.rid-portal .ph-flag.over{color:#b3382f}
.rid-portal .ph-flag.near{color:#9c6a12}
.rid-portal .ph-flag.done{color:#2f7d4f}
.rid-portal .pcard-al{display:flex;flex-direction:column;gap:3px;font-size:11.5px;margin:10px 0 2px;padding:8px 12px;border-left:3px solid #b7791f;background:#fbf6ec;color:#6b5512;border-radius:0 4px 4px 0}
.rid-portal .pcard-al.bad{border-color:#b3382f;background:#fbeeec;color:#8f2c24}

@media (max-width:760px){
  .rid-portal .qtr-grid,.rid-portal .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .rid-portal .qrow{grid-template-columns:1fr 44px 56px;gap:10px}
  .rid-portal .qrow .qcat,.rid-portal .qrow .qbarwrap{display:none}
  .rid-portal .info-tbl th{width:38%}
  .rid-portal .info-row{grid-template-columns:1fr 1fr 32px}
  .rid-portal .spot-list{grid-template-columns:1fr}
}

/* レスポンシブ（iOS15+/Chrome88+/PC直近2年） */
@media (max-width:760px){
  .rid-portal .grid{grid-template-columns:1fr}
  .rid-portal .summary{flex-wrap:wrap;gap:20px}
  .rid-portal .summary .divider{display:none}
}

/* モバイル（iPhone等 ～600px・iOS Safari 15+前提） */
@media (max-width:600px){
  .rid-portal .wrap{padding:0 18px}
  /* ヘッダ：長い表記は隠してロゴのみ＋日付/ログアウトをコンパクトに（折返し・見切れ防止） */
  .rid-portal .bar .wrap{height:auto;min-height:54px;padding:9px 0}
  .rid-portal .brand .sys{display:none}
  .rid-portal .bar .rid-logo{height:19px}
  .rid-portal .bar-right{gap:10px}
  .rid-portal .bar-right .login-as{display:none}
  .rid-portal .who .today{font-size:11.5px}
  .rid-portal .who .updated{font-size:10px}
  .rid-portal .bar .logout{padding:5px 10px;font-size:10.5px}
  .rid-portal .bar .report-btn{padding:5px 11px;font-size:10.5px}
  /* タイトル・サマリ */
  .rid-portal .head h1{font-size:25px}
  .rid-portal .phrase{gap:12px;padding:14px 16px}
  .rid-portal .phrase .phrase-t{font-size:13.5px}
  .rid-portal .phrase .phrase-p{font-size:18px}
  .rid-portal .summary .ring{--size:84px}
  /* 比較ストリップ */
  .rid-portal .cmp-item{padding:12px 12px}
  .rid-portal .cmp-v{font-size:17px}
  /* 計画方針テーブル：見出し幅を割合に */
  .rid-portal .plan-tbl th{width:38%}
  .rid-portal .plan-tbl th,.rid-portal .plan-tbl td{padding:9px 11px;font-size:12px}
  /* チェックリスト詳細：項目を折返し可に */
  .rid-portal .it{flex-wrap:wrap;gap:2px 10px}
  .rid-portal .it-right{justify-content:flex-start}
}

/* ── ロードマップ ── */
.rid-portal .rm-chart{border:1px solid var(--line);border-radius:12px;background:#fff;padding:16px 18px 20px;margin:0 0 22px;overflow:hidden}
.rid-portal .rm-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
.rid-portal .rm-inner{min-width:100%;position:relative}
.rid-portal .rm-head{position:relative;height:36px;border-bottom:1px solid var(--line)}
.rid-portal .rm-y{position:absolute;top:0;font-size:12.5px;font-weight:700;color:var(--ink);padding-left:2px}
.rid-portal .rm-t{position:absolute;top:19px;font-size:9.5px;color:var(--faint);text-align:center;letter-spacing:.08em}
.rid-portal .rm-body{position:relative;padding:14px 0 4px;min-height:56px}
.rid-portal .rm-grid{position:absolute;top:0;bottom:0;width:1px;background:#f0eeea}
.rid-portal .rm-grid.y{background:#ddd9d2}
.rid-portal .rm-today{position:absolute;top:0;bottom:0;width:2px;background:#c0392b;z-index:2}
.rid-portal .rm-row{position:relative;height:32px;margin:5px 0}
.rid-portal .rm-bar{position:absolute;top:2px;height:26px;background:var(--ink);color:#fff;font-size:11.5px;line-height:26px;border-radius:7px;padding:0 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:40px}
.rid-portal .rm-bar.done{background:#b9b5ae}
.rid-portal .rm-bar.off{background:#e8e5e0;color:var(--sub);text-decoration:line-through}
.rid-portal .rm-near{font-style:normal;font-size:9.5px;background:#fbf6ec;color:#9c6a12;border-radius:99px;padding:1px 7px;margin-left:7px;vertical-align:1px}
.rid-portal .rm-dn{font-style:normal;font-size:9.5px;background:rgba(255,255,255,.22);border-radius:99px;padding:1px 7px;margin-left:7px;vertical-align:1px}
/* 1行に2枚（リスト化）。狭い画面では1列に折り返す */
.rid-portal .rm-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:18px}
/* ロードマップ＝構想カード（プロジェクトカードと同じ見た目） */
.rid-portal .rm-item{background:var(--card);border:1px solid var(--line);padding:22px 24px 20px;position:relative}
.rid-portal .rm-item.editing{grid-column:1/-1}   /* 編集中は横幅いっぱいに */
.rid-portal .rm-item.dim{opacity:.6}
.rid-portal .rm-item.pend{border-style:dashed;opacity:.82}
.rid-portal .rm-badge{position:absolute;top:16px;right:18px;font-size:10.5px;padding:3px 11px;border-radius:99px;letter-spacing:.04em;background:var(--ink);color:#fff;white-space:nowrap}
.rid-portal .rm-badge.un{background:#fff;color:var(--sub);border:1px solid var(--line)}
.rid-portal .rm-badge.go{background:#2f7d4f;color:#fff}
.rid-portal .rm-badge.ok{background:#3a6b3a;color:#fff}
.rid-portal .rm-badge.off{background:#f3f1ee;color:var(--faint)}
.rid-portal .rm-eyebrow{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--sub);padding-right:90px}
.rid-portal .rm-name{margin:5px 0 2px;font-size:16px;font-weight:600;color:var(--ink)}
.rid-portal .rm-sum{font-size:12.5px;color:var(--sub);line-height:1.55;margin:9px 0 0}
.rid-portal .rm-sales-r{font-size:11.5px;color:#266658;margin:8px 0 0}
.rid-portal .rm-st{font-size:10.5px;color:var(--sub);background:var(--chip);border-radius:99px;padding:3px 10px;text-align:center;white-space:nowrap}
.rid-portal .rm-st.go{background:#e7f3ea;color:#2f7d4f}
.rid-portal .rm-st.ok{background:#eef4ee;color:#3a6b3a}
.rid-portal .rm-st.off{background:#f3f1ee;color:var(--faint)}
.rid-portal .rm-deliv-box{margin:11px 0 0;padding:10px 12px;border:1px solid var(--line-2);border-radius:9px;background:#fbfaf8}
.rid-portal .rm-deliv-h{font-size:10.5px;letter-spacing:.12em;color:var(--faint);font-weight:700;margin-bottom:6px}
.rid-portal .rm-d{display:flex;align-items:center;gap:10px;padding:5px 0;border-bottom:1px solid var(--line-2)}
.rid-portal .rm-d:last-child{border-bottom:none}
.rid-portal .rm-d-n{flex:1;font-size:12.5px;font-weight:600;color:var(--ink);word-break:break-all}
.rid-portal .rm-d-done{font-size:11px;font-weight:600;color:#2f7d4f;white-space:nowrap}
.rid-portal .rm-d-ok{font-size:11px;font-weight:600;color:#2f7d4f;white-space:nowrap}
.rid-portal .rm-d-wait{font-size:11px;color:var(--faint);white-space:nowrap}
/* 構想の編集・削除（マネージャー＝提案） */
.rid-portal .rm-edit-wrap{margin-top:11px;border-top:1px solid var(--line-2);padding-top:10px}
.rid-portal .rm-edit-act{display:flex;gap:8px;align-items:center}
.rid-portal .rm-edit-btn,.rid-portal .rm-del-btn{font-family:inherit;font-size:11.5px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:7px;padding:5px 13px;cursor:pointer}
.rid-portal .rm-edit-btn:hover{border-color:var(--ink)}
.rid-portal .rm-del-btn{color:#c0392b;border-color:#e3c4c0}
.rid-portal .rm-del-btn:hover{background:#fbeeec}
.rid-portal .rm-pend-note{font-size:11px;color:#9c6a12;background:#fbf6ec;border-radius:99px;padding:3px 12px}
.rid-portal .rm-edit-form{display:flex;gap:9px;align-items:center;flex-wrap:wrap;margin-top:11px;padding:12px;border:1px dashed var(--line);border-radius:9px;background:#fdfcfa}
.rid-portal .rm-edit-form .re-title{min-width:220px;flex:1;font-family:inherit;font-size:12.5px;border:1px solid var(--line);border-radius:7px;padding:8px 10px;background:#fff}
.rid-portal .rm-edit-form .re-summary{min-width:200px;flex:1;font-family:inherit;font-size:12.5px;border:1px solid var(--line);border-radius:7px;padding:8px 10px;background:#fff}
.rid-portal .rm-edit-form select{font-family:inherit;font-size:12px;border:1px solid var(--line);border-radius:7px;padding:7px;background:#fff}
.rid-portal .rm-edit-form .re-sales{font-family:inherit;font-size:12px;border:1px solid var(--line);border-radius:7px;padding:6px 8px;background:#fff}
.rid-portal .rm-edit-form .re-deliv{flex-basis:100%;min-height:110px;font-family:inherit;font-size:12.5px;border:1px solid var(--line);border-radius:7px;padding:8px 10px;background:#fff;resize:vertical;line-height:1.6}
.rid-portal .rm-edit-form .re-locked-note{flex-basis:100%;margin:0}
.rid-portal .rm-edit-go{flex-basis:100%;display:flex;gap:8px}
.rid-portal .rm-edit-form .re-save{font-family:inherit;font-size:12px;border:1px solid var(--ink);background:var(--ink);color:#fff;border-radius:8px;padding:8px 16px;cursor:pointer}
.rid-portal .rm-edit-form .re-cancel{font-family:inherit;font-size:12px;border:1px solid var(--line);background:#fff;color:var(--sub);border-radius:8px;padding:8px 14px;cursor:pointer}
/* 概要の接近確認ボックス */
.rid-portal .rmask{border:1px solid #e3d9c2;background:#fdfaf2;border-radius:10px;padding:14px 16px;margin:0 0 18px}
.rid-portal .rmask-h{font-size:13px;font-weight:600;color:#7d5a14;margin-bottom:10px}
.rid-portal .rmask-h .mk{font-size:11px;margin-right:2px}
.rid-portal .rmask-list{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.rid-portal .rmask-list li{display:grid;grid-template-columns:86px 1fr auto;gap:12px;align-items:center;font-size:12.5px;color:var(--ink)}
.rid-portal .rma-when{font-size:10px;text-align:center;border-radius:99px;padding:3px 0;background:#efe7d3;color:#7d5a14;white-space:nowrap}
.rid-portal .rma-when.past{background:#c0392b;color:#fff}
.rid-portal .rma-sum{font-style:normal;font-size:11px;color:var(--sub);margin-left:8px}
.rid-portal .rma-act{display:flex;gap:8px;align-items:center}
.rid-portal .rma-go{font-family:inherit;font-size:11.5px;border:1px solid var(--ink);background:var(--ink);color:#fff;border-radius:8px;padding:6px 14px;cursor:pointer}
.rid-portal .rma-go:hover{opacity:.85}
.rid-portal .rma-hold{font-family:inherit;font-size:11.5px;border:1px solid var(--line);background:#fff;color:var(--sub);border-radius:8px;padding:6px 12px;cursor:pointer}
.rid-portal .rma-hold:hover{border-color:var(--ink);color:var(--ink)}
.rid-portal .rma-go:disabled,.rid-portal .rma-hold:disabled{opacity:.5;cursor:default}
.rid-portal .rma-sent{font-size:11.5px;color:var(--sub)}
/* 一覧の下の「構想を追加」ボタン（クリックでフォームを開く） */
.rid-portal .rm-add-open{display:block;width:100%;margin-top:16px;font-family:inherit;font-size:13px;font-weight:600;color:var(--ink);background:var(--card);border:1px dashed var(--line);border-radius:10px;padding:13px;cursor:pointer;transition:border-color .15s,background .15s}
.rid-portal .rm-add-open:hover{border-color:var(--ink);background:#fbfaf8}
.rid-portal .rm-add-go-row{flex-basis:100%;display:flex;gap:8px}
.rid-portal .rm-add .rm-add-cancel{font-family:inherit;font-size:12px;border:1px solid var(--line);background:#fff;color:var(--sub);border-radius:8px;padding:8px 14px;cursor:pointer}
.rid-portal .rm-add{display:flex;gap:10px;align-items:center;flex-wrap:wrap;border:1px dashed var(--line);border-radius:10px;padding:14px 16px;background:#fdfcfa;margin-top:14px}
.rid-portal .rm-add input[type=text]{font-family:inherit;font-size:12.5px;border:1px solid var(--line);border-radius:7px;padding:8px 10px;background:#fff}
.rid-portal .rm-add .rm-add-title{min-width:250px;flex:1}
.rid-portal .rm-add .rm-add-summary{min-width:200px;flex:1}
.rid-portal .rm-add .rm-add-l{font-size:11px;color:var(--sub);display:flex;align-items:center;gap:6px}
.rid-portal .rm-add .rm-add-l input{font-family:inherit;font-size:12px;border:1px solid var(--line);border-radius:7px;padding:6px 8px;background:#fff}
.rid-portal .rm-add .rm-add-deliv{flex-basis:100%;min-height:110px;font-family:inherit;font-size:12.5px;border:1px solid var(--line);border-radius:7px;padding:8px 10px;background:#fff;resize:vertical;line-height:1.6}
.rid-portal .rm-add select{font-family:inherit;font-size:12px;border:1px solid var(--line);border-radius:7px;padding:7px;background:#fff}
.rid-portal .rm-add-go{font-family:inherit;font-size:12px;border:1px solid var(--ink);background:var(--ink);color:#fff;border-radius:8px;padding:8px 16px;cursor:pointer;white-space:nowrap}
.rid-portal .rm-add-go:hover{opacity:.85}
.rid-portal .rm-add-go:disabled{opacity:.5;cursor:default}
.rid-portal .rm-add-note{width:100%;margin:2px 0 0}
/* 却下された提案のお知らせ */
.rid-portal .rejalert{border:1px solid var(--line);background:#f7f6f4;border-radius:10px;padding:14px 16px;margin:0 0 18px}
.rid-portal .rejalert-h{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:10px}
.rid-portal .rejalert-h .mk{font-size:11px;margin-right:2px;color:var(--sub)}
.rid-portal .rejalert-list{list-style:none;margin:0;padding:0;display:grid;gap:7px}
.rid-portal .rejalert-list li{display:grid;grid-template-columns:46px 150px 1fr;gap:10px;align-items:center;font-size:12.5px;color:var(--ink)}
.rid-portal .rj-when{font-size:11px;color:var(--sub);white-space:nowrap}
.rid-portal .rj-kind{font-size:10.5px;color:var(--sub);background:var(--chip);border-radius:99px;padding:2px 9px;text-align:center;white-space:nowrap}
.rid-portal .rj-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rid-portal .rejalert-list li.rj-go{cursor:pointer}
.rid-portal .rejalert-list li.rj-go:hover .rj-desc{text-decoration:underline}
.rid-portal .mypend-list .mp-desc.go{cursor:pointer}
.rid-portal .mypend-list .mp-desc.go:hover{text-decoration:underline}
.rid-portal .rmask-list .rma-item.go{cursor:pointer}
.rid-portal .rmask-list .rma-item.go:hover{text-decoration:underline}
.rid-portal .rejalert-note{margin:10px 0 0}
.rid-portal .rejalert-ok{margin-top:10px;font-family:inherit;font-size:11.5px;border:1px solid var(--line);background:#fff;color:var(--sub);border-radius:8px;padding:7px 14px;cursor:pointer}
.rid-portal .rejalert-ok:hover{border-color:var(--ink);color:var(--ink)}
.rid-portal .rejalert-ok:disabled{opacity:.5;cursor:default}
/* 自分の承認待ち提案（修正・取り下げ） */
.rid-portal .mypend{border:1px solid var(--line);background:#fff;border-radius:10px;padding:14px 16px;margin:0 0 18px}
.rid-portal .mypend-h{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:10px}
.rid-portal .mypend-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.rid-portal .mp-row{display:grid;grid-template-columns:46px 150px 1fr auto;gap:10px;align-items:center;font-size:12.5px;color:var(--ink)}
.rid-portal .mp-when{font-size:11px;color:var(--sub);white-space:nowrap}
.rid-portal .mp-kind{font-size:10.5px;color:var(--sub);background:var(--chip);border-radius:99px;padding:2px 9px;text-align:center;white-space:nowrap}
.rid-portal .mp-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rid-portal .mp-extra{font-style:normal;font-size:11px;color:var(--sub);margin-left:8px}
.rid-portal .mp-act{display:flex;gap:8px}
.rid-portal .mp-edit,.rid-portal .mp-del{font-family:inherit;font-size:11px;border:1px solid var(--line);background:#fff;color:var(--sub);border-radius:7px;padding:4px 12px;cursor:pointer;white-space:nowrap}
.rid-portal .mp-edit:hover{border-color:var(--ink);color:var(--ink)}
.rid-portal .mp-del:hover{border-color:#c0392b;color:#c0392b}
.rid-portal .mp-edit:disabled,.rid-portal .mp-del:disabled{opacity:.5;cursor:default}
.rid-portal .mp-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:8px 0 4px 56px;padding:10px 12px;border:1px dashed var(--line);border-radius:8px;background:#fdfcfa}
.rid-portal .mp-form[hidden]{display:none}
.rid-portal .mpf-text{font-family:inherit;font-size:12px;border:1px solid var(--line);border-radius:6px;padding:6px 8px;min-width:220px;flex:1}
.rid-portal .mpf-short{min-width:120px;flex:0 1 140px}
.rid-portal .mpf-ta{font-family:inherit;font-size:12px;border:1px solid var(--line);border-radius:6px;padding:6px 8px;width:100%}
.rid-portal .mpf-date,.rid-portal .mpf-sel{font-family:inherit;font-size:12px;border:1px solid var(--line);border-radius:6px;padding:5px 7px;background:#fff}
.rid-portal .mpf-l{font-size:10.5px;color:var(--faint)}
.rid-portal .mpf-save{font-family:inherit;font-size:11.5px;border:1px solid var(--ink);background:var(--ink);color:#fff;border-radius:7px;padding:6px 14px;cursor:pointer}
.rid-portal .mpf-save:hover{opacity:.85}
.rid-portal .mpf-save:disabled{opacity:.5;cursor:default}
.rid-portal .mpf-cancel{font-family:inherit;font-size:11.5px;border:1px solid var(--line);background:#fff;color:var(--sub);border-radius:7px;padding:6px 12px;cursor:pointer}

/* ── プロジェクトの「資料」ボタン＋ホワイトボード（Excalidraw）モーダル ── */
.rid-portal .pj-actions{margin-top:12px}
.rid-portal .pj-board{font-family:inherit;font-size:12px;font-weight:600;letter-spacing:.02em;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:8px;padding:7px 16px;cursor:pointer;transition:border-color .15s,background .15s,color .15s}
.rid-portal .pj-board:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.rid-portal .pj-board::before{content:"\1F5CB\FE0E";margin-right:6px;opacity:.7}
.rid-portal .pj-board:hover::before{opacity:1}
.rid-portal .dh .pj-board.dh-board{font-size:11px;padding:3px 11px;margin-left:auto}
.rid-portal .dh .detail-close{margin-left:8px}

.rid-wb-modal{position:fixed;inset:0;z-index:9999;background:rgba(24,24,24,.55);display:flex;align-items:center;justify-content:center;padding:2vmin}
.rid-wb-modal[hidden]{display:none}
.rid-wb-box{width:96vw;height:94vh;background:var(--paper,#faf9f7);border-radius:12px;box-shadow:0 24px 80px rgba(0,0,0,.4);display:flex;flex-direction:column;overflow:hidden}
.rid-wb-head{flex:0 0 auto;display:flex;align-items:center;gap:14px;padding:10px 16px;background:#181818;color:#faf9f7}
.rid-wb-ttl{display:flex;align-items:baseline;gap:10px;min-width:0}
.rid-wb-ey{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#9a9a9a;flex:0 0 auto}
.rid-wb-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rid-wb-meta{flex:1 1 auto;font-size:11.5px;color:#bdbdbd;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rid-wb-act{flex:0 0 auto;display:flex;align-items:center;gap:8px}
.rid-wb-save{font-family:inherit;font-size:12.5px;font-weight:600;color:#181818;background:#faf9f7;border:none;border-radius:7px;padding:6px 18px;cursor:pointer}
.rid-wb-save:hover{opacity:.85}
.rid-wb-save:disabled{opacity:.5;cursor:default}
.rid-wb-close{font-family:inherit;font-size:12px;color:#faf9f7;background:transparent;border:1px solid #555;border-radius:7px;padding:6px 12px;cursor:pointer}
.rid-wb-close:hover{border-color:#faf9f7}
.rid-wb-canvas{flex:1 1 auto;position:relative;min-height:0;background:#fff}
.rid-wb-canvas .excalidraw{height:100%}

/* ── 「あなたのタスク」右パネル（常時・スクロール・開閉） ── */
.rid-myt{position:fixed;right:0;top:132px;bottom:16px;z-index:900;display:flex;align-items:flex-start;pointer-events:none}
.rid-myt>*{pointer-events:auto}
.rid-myt[data-open="1"] .rid-myt-handle{display:none}
.rid-myt[data-open="0"] .rid-myt-panel{display:none}
.rid-myt[data-open="1"] .rid-myt-panel{display:flex}
.rid-myt[data-open="0"] .rid-myt-handle{display:inline-flex}
/* 折りたたみ時のタブ：右上のいい位置に。縦書きで「あなたのタスク」＋件数 */
.rid-myt-handle{align-self:flex-start;margin-top:8px;flex-direction:row;align-items:center;gap:8px;writing-mode:vertical-rl;font-family:inherit;font-size:12.5px;font-weight:700;letter-spacing:.14em;color:#faf9f7;background:var(--ink);border:none;border-radius:12px 0 0 12px;padding:18px 10px;cursor:pointer;box-shadow:-3px 3px 16px rgba(0,0,0,.22);transition:padding-right .15s}
.rid-myt-handle:hover{padding-right:14px}
.rid-myt-hn{writing-mode:horizontal-tb;background:#faf9f7;color:var(--ink);border-radius:99px;font-size:11px;font-weight:700;padding:1px 7px;min-width:18px;text-align:center}
.rid-myt-panel{flex-direction:column;width:312px;max-width:90vw;height:100%;background:var(--card,#fff);border:1px solid var(--line);border-right:none;border-radius:12px 0 0 12px;box-shadow:-6px 6px 34px rgba(0,0,0,.18);overflow:hidden}
.rid-myt-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:11px 14px;background:var(--ink);color:#faf9f7}
.rid-myt-ttl{font-size:13px;font-weight:700;letter-spacing:.04em}
.rid-myt-collapse{font-family:inherit;font-size:20px;line-height:1;color:#faf9f7;background:transparent;border:none;cursor:pointer;padding:0 4px}
.rid-myt-sub{flex:0 0 auto;padding:8px 14px;font-size:11px;color:var(--sub);border-bottom:1px solid var(--line);background:#faf9f7}
.rid-myt-sub b{color:var(--ink)}
.rid-myt-list{flex:1 1 auto;overflow-y:auto;padding:7px}
.rid-myt-empty{font-size:12px;color:var(--sub);padding:16px 10px;line-height:1.6}
.rid-myt-row{padding:9px 10px;border:1px solid var(--line);border-radius:9px;margin-bottom:6px;cursor:pointer;background:#fff;transition:border-color .12s,background .12s}
.rid-myt-row:hover{border-color:var(--ink);background:#faf9f7}
.rid-myt-row.done{opacity:.5}
.rid-myt-r1{display:flex;align-items:center;gap:7px;margin-bottom:4px}
.rid-myt-ph{flex:0 0 auto;font-size:9.5px;font-weight:700;letter-spacing:.06em;color:#fff;background:var(--ink);border-radius:4px;padding:1px 6px}
.rid-myt-ph.sup{background:#6b5b95}
.rid-myt-pj{font-size:10.5px;color:var(--sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rid-myt-it{font-size:12.5px;font-weight:600;color:var(--ink);line-height:1.35;margin-bottom:5px}
.rid-myt-r3{display:flex;align-items:center;gap:12px;font-size:10.5px;color:var(--sub)}
.rid-myt-st{display:inline-flex;align-items:center;gap:5px}
.rid-myt-due{color:var(--ink)}
/* 自分用の締切（あなたのタスク内・自分だけ・フェーズ期間内のみ選べる）*/
.rid-myt-pd{display:flex;align-items:center;gap:7px;margin-top:7px;font-size:10px;color:#266658;cursor:default}
.rid-myt-pd-in{font-family:inherit;font-size:11px;color:#266658;background:#f0f7f4;border:1px solid #bcdcd2;border-radius:6px;padding:3px 6px;cursor:pointer}
.rid-myt-pd-in:focus{outline:none;border-color:#2f7d6a}
@media(max-width:1099px){.rid-myt{top:auto;bottom:0;height:auto;max-height:82vh}.rid-myt-panel{height:72vh}}
/* 自分の締切アラート（ダッシュボード上部・自分だけ・ティール）*/
.rid-portal .pd-alert{border:1px solid #bcdcd2;background:#f0f7f4;border-radius:10px;padding:13px 17px;margin:0 0 20px}
.rid-portal .pd-alert-h{font-size:13.5px;font-weight:700;color:#266658;margin-bottom:8px;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.rid-portal .pd-alert-h b{font-size:15px}
.rid-portal .pd-alert-note{font-size:11px;font-weight:400;color:#7aa89b}
.rid-portal .pd-alert-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.rid-portal .pd-alert-row{display:flex;align-items:center;gap:10px;padding:7px 9px;border-radius:8px;cursor:pointer;border:1px solid transparent}
.rid-portal .pd-alert-row:hover{background:#e6f1ec;border-color:#bcdcd2}
.rid-portal .pd-alert .pd-k{flex:0 0 auto;font-size:10px;font-weight:700;border-radius:4px;padding:1px 7px;color:#fff}
.rid-portal .pd-alert .pd-k.over{background:#b3382f}.rid-portal .pd-alert .pd-k.near{background:#b07b2f}
.rid-portal .pd-alert .pd-it{flex:1;font-size:12.5px;color:#181818;word-break:break-all}
.rid-portal .pd-alert .pd-due{flex:0 0 auto;color:#7aa89b;font-size:11px;white-space:nowrap}

/* 共有フォルダの新着バナー（アプリ監視→送信） */
.rid-portal .folder-alert{border:1px solid #cdb4a0;background:#fbf6f1;border-radius:10px;padding:14px 18px;margin:0 0 20px}
.rid-portal .folder-alert .fa-h{font-size:14px;font-weight:700;color:#7a4a25;margin-bottom:9px;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.rid-portal .folder-alert .fa-h b{font-size:16px}
.rid-portal .folder-alert .fa-hint{font-size:11px;font-weight:600;color:#a8927f}
.rid-portal .folder-alert .fa-list{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.rid-portal .folder-alert .fa-row{display:block;padding:8px 10px;border-radius:8px;border:1px solid transparent}
.rid-portal .folder-alert .fa-n{display:block;font-size:13.5px;font-weight:600;color:#181818;word-break:break-all;line-height:1.45}
.rid-portal .folder-alert .fa-meta{display:flex;align-items:center;gap:10px;margin-top:5px;flex-wrap:wrap}
.rid-portal .folder-alert .fa-k{flex:0 0 auto;font-size:10px;font-weight:700;border-radius:4px;padding:1px 8px;color:#fff}
.rid-portal .folder-alert .fa-k.add{background:#2f7d4f}.rid-portal .folder-alert .fa-k.mod{background:#b07b2f}
.rid-portal .folder-alert .fa-t{flex:0 0 auto;color:#a8927f;font-size:11px;white-space:nowrap}
.rid-portal .folder-alert .fa-acts{display:flex;gap:7px;margin-left:auto}
.rid-portal .folder-alert .fa-act{font-size:11px;font-weight:600;color:#7a4a25;background:#fff;border:1px solid #d8c2af;border-radius:6px;padding:3px 10px;text-decoration:none;white-space:nowrap}
.rid-portal .folder-alert .fa-act:hover{background:#7a4a25;color:#fff;border-color:#7a4a25}
.rid-portal .folder-alert .fa-ack{font-family:inherit;font-size:12px;font-weight:600;color:#7a4a25;background:#fff;border:1px solid #cdb4a0;border-radius:7px;padding:7px 15px;cursor:pointer}
.rid-portal .folder-alert .fa-ack:hover{background:#7a4a25;color:#fff}
