/* RiD Meeting Flow — 会議申請ポータル（白黒・マットブラック）
   方針：RiD共通UIスタイル（Project Report Portal 調）。真っ黒#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;
  --ok:#2f7d4f; --bad:#b3382f; --warn:#9c6a12;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.mf-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;min-height:100vh;
  display:flex;flex-direction:column;
}
.mf-portal .wrap{max-width:920px;margin:0 auto;padding:0 28px;width:100%}
.mf-portal main.wrap{flex:1}

/* ── ヘッダ（マットブラック帯62px） ── */
.mf-portal header.bar{background:var(--ink);color:#fff}
.mf-portal .bar .wrap{display:flex;align-items:center;justify-content:space-between;height:62px}
.mf-portal .brand{display:flex;align-items:center;gap:12px}
.mf-portal .brand .app-logo{display:block;height:30px;width:30px;border-radius:7px}
.mf-portal .brand .sys{font-weight:700;letter-spacing:.26em;font-size:13.5px}
.mf-portal .bar-right{display:flex;align-items:center;gap:14px}
.mf-portal .bar .ver{font-size:11px;letter-spacing:.18em;color:#b9b8b3}
.mf-portal .bar .rid-mark{display:block;height:18px;width:auto;opacity:.92}
.mf-portal .bar-right .login-as{font-size:11.5px;color:#b9b8b3;letter-spacing:.02em;white-space:nowrap}
.mf-portal .bar-right .login-as b{color:#fff;font-weight:600}
.mf-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}
.mf-portal .bar .logout:hover{color:#fff;border-color:#8a8a8a}

/* ── サブバー ── */
.mf-portal .subbar{background:var(--card);border-bottom:1px solid var(--line)}
.mf-portal .subbar .wrap{display:flex;align-items:center;gap:8px;padding:11px 28px;font-size:12.5px;flex-wrap:wrap;color:var(--sub)}
.mf-portal .subbar .sb-l{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.mf-portal .subbar .sb-sep{color:var(--line);margin:0 4px}
.mf-portal .sb-demo{font-size:10.5px;letter-spacing:.04em;color:#7d5a14;background:#fdfaf2;border:1px solid #e3d9c2;border-radius:99px;padding:2px 11px;margin-left:auto}
.mf-portal .sb-live{font-size:10.5px;letter-spacing:.08em;color:#fff;background:var(--ink);border-radius:99px;padding:2px 12px;margin-left:auto}
.mf-portal .sb-sample{font-size:10.5px;letter-spacing:.04em;color:#3a5a85;background:#eef2f7;border:1px solid #cdd9e6;border-radius:99px;padding:2px 12px;margin-left:auto}

/* ── タブ ── */
.mf-portal .tabs{background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.mf-portal .tabs .wrap{display:flex;gap:2px;overflow-x:auto}
.mf-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}
.mf-portal .tab:hover{color:var(--ink)}
.mf-portal .tab.active{color:var(--ink);font-weight:600;border-bottom-color:var(--ink)}
.mf-portal .tabs .tab:first-child{padding-left:0}
.mf-portal .view{display:none;padding-bottom:56px}
.mf-portal .view.active{display:block}

/* ── タイトル ── */
.mf-portal .head{padding:42px 0 24px}
.mf-portal .eyebrow{font-size:11px;letter-spacing:.3em;color:var(--faint);text-transform:uppercase;margin-bottom:12px}
.mf-portal .head h1{font-size:27px;font-weight:600;letter-spacing:.02em}
.mf-portal .head .meta{margin-top:10px;font-size:12.5px;color:var(--sub);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.mf-portal .req-note{color:var(--faint);font-size:11.5px}

/* ── フラッシュ ── */
.mf-portal .flash{margin:22px 0 0;padding:13px 18px;font-size:13px;border:1px solid var(--line);background:var(--card);border-left:3px solid var(--ink)}
.mf-portal .flash.ok{border-left-color:var(--ok)}
.mf-portal .flash.ng{border-left-color:var(--bad);color:#7a2a24}
.mf-portal .flash.warn{border-left-color:var(--warn);background:#fdfaf2}

/* ── フォーム ── */
.mf-portal .mf-form{margin-top:8px}
.mf-portal .fset{margin:0 0 18px}
.mf-portal .fl{display:block;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--ink-2);margin-bottom:7px}
.mf-portal .fl.req::after{content:'＊';color:var(--bad);margin-left:4px;font-weight:700}
.mf-portal .fl-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:7px}
.mf-portal .fl-row .fl{margin-bottom:0}
.mf-portal .agenda-total{font-size:12px;color:var(--sub)}
.mf-portal .agenda-total b{font-size:15px;color:var(--ink);font-weight:600}
.mf-portal .fi{width:100%;font-family:inherit;font-size:14px;color:var(--ink);background:var(--card);
  border:1px solid var(--line);border-radius:2px;padding:10px 12px;transition:border-color .15s}
.mf-portal .fi:focus{outline:none;border-color:var(--ink)}
.mf-portal textarea.fi{resize:vertical;line-height:1.6}
.mf-portal .grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.mf-portal .grid3{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:16px}

/* ハニーポット（人には不可視） */
.mf-portal .mf-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* 進行内容（行） */
.mf-portal .agenda{border:1px solid var(--line);background:var(--card);border-radius:2px;overflow:hidden}
.mf-portal .ag-head,.mf-portal .ag-row{display:grid;grid-template-columns:1.3fr 1.5fr 90px 34px;gap:0;align-items:center}
.mf-portal .ag-head{background:#f7f6f3;border-bottom:1px solid var(--line);font-size:11px;color:var(--sub);letter-spacing:.04em}
.mf-portal .ag-head span{padding:9px 12px}
.mf-portal .ag-row{border-bottom:1px solid var(--line-2)}
.mf-portal .ag-row:last-child{border-bottom:0}
.mf-portal .ag-row .fi{border:0;border-right:1px solid var(--line-2);border-radius:0;background:transparent}
.mf-portal .ag-row .fi:focus{background:#fcfcfa;box-shadow:inset 0 0 0 1px var(--ink)}
.mf-portal .ag-row .ag-min{text-align:right}
.mf-portal .ag-del{border:0;background:transparent;color:var(--faint);font-size:17px;cursor:pointer;height:100%;transition:.15s}
.mf-portal .ag-del:hover{color:var(--bad)}
.mf-portal #ag-add{margin-top:10px}

/* ── ボタン ── */
.mf-portal .btn-fill{display:inline-block;font-family:inherit;font-size:14px;font-weight:600;letter-spacing:.04em;
  color:#fff;background:var(--ink);border:1px solid var(--ink);padding:12px 28px;border-radius:2px;cursor:pointer;transition:.15s}
.mf-portal .btn-fill:hover{background:#000}
.mf-portal .btn-fill:disabled{opacity:.5;cursor:default}
.mf-portal .btn-line{display:inline-block;font-family:inherit;font-size:13px;letter-spacing:.03em;color:var(--ink);
  background:var(--card);border:1px solid var(--line);padding:9px 16px;border-radius:2px;cursor:pointer;text-decoration:none;transition:.15s}
.mf-portal .btn-line:hover{border-color:var(--ink)}
.mf-portal .btn-line.sm{padding:5px 12px;font-size:11.5px}
.mf-portal .btn-line.danger:hover{border-color:var(--bad);color:var(--bad)}
.mf-portal .mf-actions{display:flex;align-items:center;gap:16px;margin-top:30px;padding-top:24px;border-top:1px solid var(--ink);flex-wrap:wrap}
.mf-portal .mf-note{font-size:11.5px;color:var(--faint)}

/* ── 一覧 ── */
.mf-portal .empty{padding:40px;text-align:center;color:var(--faint);border:1px dashed var(--line);background:var(--card);font-size:13px}
.mf-portal .mf-list{display:grid;gap:8px}
.mf-portal .mf-card{display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:var(--card);border:1px solid var(--line);border-left:3px solid var(--track);padding:15px 18px}
.mf-portal .mf-card.st-pending{border-left-color:var(--warn)}
.mf-portal .mf-card.st-approved{border-left-color:var(--ok)}
.mf-portal .mf-card.st-canceled{opacity:.6}
.mf-portal .mc-top{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.mf-portal .mc-title{font-size:14.5px;font-weight:600}
.mf-portal .mc-meta{display:flex;gap:14px;font-size:11.5px;color:var(--sub);flex-wrap:wrap}
.mf-portal .mc-err{color:var(--bad)}
.mf-portal .mc-act{display:flex;gap:8px;flex-shrink:0}

/* バッジ */
.mf-portal .badge{display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.06em;padding:3px 11px;border-radius:99px;white-space:nowrap}
.mf-portal .b-pending{background:#fdfaf2;color:var(--warn);border:1px solid #e3d9c2}
.mf-portal .b-approved{background:#eef6f1;color:var(--ok);border:1px solid #cfe6da}
.mf-portal .b-canceled{background:var(--chip);color:var(--faint);border:1px solid var(--line)}

/* ── フッタ ── */
.mf-portal .mf-foot{border-top:1px solid var(--line);background:var(--card)}
.mf-portal .mf-foot .wrap{padding:18px 28px;font-size:10.5px;letter-spacing:.14em;color:var(--faint);text-transform:uppercase}

/* ════════ ログイン画面 ════════ */
.mf-login-page{justify-content:center;align-items:center}
.mf-portal.mf-login-page{display:flex}
.login-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px}
.login-card{width:100%;max-width:360px;background:var(--card);border:1px solid var(--line);padding:40px 34px 30px;border-radius:3px}
.login-h{text-align:center;margin-bottom:26px}
.login-logo{width:54px;height:54px;border-radius:13px;display:block;margin:0 auto 16px}
.login-sys{font-size:15px;font-weight:700;letter-spacing:.26em;color:var(--ink)}
.login-sub{font-size:11.5px;color:var(--sub);margin-top:6px;letter-spacing:.06em}
.mf-login-page #loginform label,.mf-login-page .login-card label{display:block;font-size:12px;color:var(--ink-2);margin-bottom:14px;font-weight:600}
.mf-login-page .login-card input[type=text],.mf-login-page .login-card input[type=password]{
  width:100%;font-size:14px;padding:10px 12px;border:1px solid var(--line);border-radius:2px;margin-top:6px;font-weight:400}
.mf-login-page .login-card input:focus{outline:none;border-color:var(--ink)}
.mf-login-page .login-card .button,.mf-login-page .login-card #wp-submit{
  width:100%;background:var(--ink);color:#fff;border:1px solid var(--ink);border-radius:2px;
  padding:11px;font-size:14px;font-weight:600;letter-spacing:.06em;cursor:pointer;margin-top:8px}
.mf-login-page .login-card .button:hover{background:#000}
.mf-login-page .login-remember{font-weight:400!important;font-size:12px!important;color:var(--sub)!important}
.login-foot{text-align:center;font-size:10px;letter-spacing:.14em;color:var(--faint);margin-top:22px;text-transform:uppercase}

/* ════════ 印刷シート ════════ */
.mf-sheet-body{background:#f0efec;margin:0;
  font-family:-apple-system,"Hiragino Sans","Noto Sans JP",sans-serif;color:#181818}
.mf-sheet{max-width:760px;margin:30px auto;background:#fff;border:1px solid #e7e6e2;padding:44px 48px}
.mf-sheet .sh-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid #181818;padding-bottom:16px;margin-bottom:22px}
.mf-sheet .sh-eyebrow{font-size:10px;letter-spacing:.3em;color:#a8a6a0;text-transform:uppercase;margin-bottom:6px}
.mf-sheet h1{font-size:23px;font-weight:600;letter-spacing:.04em}
.mf-sheet .sh-status{align-self:center}
.mf-sheet table{width:100%;border-collapse:collapse;font-size:13px}
.mf-sheet .sh-table th{width:90px;text-align:left;background:#f7f6f3;border:1px solid #e7e6e2;padding:9px 12px;font-weight:600;color:#2b2b2b;vertical-align:top;white-space:nowrap}
.mf-sheet .sh-table td{border:1px solid #e7e6e2;padding:9px 12px;vertical-align:top}
.mf-sheet .sh-sec{margin:24px 0 10px;font-size:13.5px;font-weight:700;letter-spacing:.04em;border-left:3px solid #181818;padding-left:10px;display:flex;justify-content:space-between;align-items:baseline}
.mf-sheet .sh-total{font-size:11.5px;font-weight:500;color:#7a7873}
.mf-sheet .sh-agenda th{background:#181818;color:#fff;border:1px solid #181818;padding:8px 12px;font-weight:600;text-align:left}
.mf-sheet .sh-agenda td{border:1px solid #e7e6e2;padding:8px 12px;vertical-align:top}
.mf-sheet .sh-agenda .c-no{width:40px;text-align:center;color:#7a7873}
.mf-sheet .sh-agenda .c-min{width:80px;text-align:right}
.mf-sheet .sh-box{border:1px solid #e7e6e2;padding:12px 14px;font-size:13px;min-height:48px;line-height:1.7;white-space:pre-wrap}
.mf-sheet .dim{color:#a8a6a0;text-align:center}
.mf-sheet .sh-foot{display:flex;gap:24px;flex-wrap:wrap;margin-top:26px;padding-top:14px;border-top:1px solid #e7e6e2;font-size:11px;color:#7a7873}
.mf-sheet .sh-print{margin-top:22px;text-align:center}
.mf-sheet .badge{display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.06em;padding:3px 11px;border-radius:99px}
.mf-sheet .b-pending{background:#fdfaf2;color:#9c6a12;border:1px solid #e3d9c2}
.mf-sheet .b-approved{background:#eef6f1;color:#2f7d4f;border:1px solid #cfe6da}
.mf-sheet .b-canceled{background:#f3f2ee;color:#a8a6a0;border:1px solid #e7e6e2}
.mf-sheet .btn-fill{display:inline-block;font-size:14px;font-weight:600;letter-spacing:.04em;color:#fff;background:#181818;border:1px solid #181818;padding:11px 28px;border-radius:2px;cursor:pointer}

@media print{
  .mf-sheet-body{background:#fff}
  .mf-sheet{margin:0;border:0;padding:0;max-width:none}
  .sh-print{display:none!important}
}

/* ── 達成率ドーナツ ── */
.mf-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}
.mf-portal .ring::before{content:"";position:absolute;inset:calc(var(--size)/9);border-radius:50%;background:var(--paper)}
.mf-portal .ring .val{position:relative;font-size:calc(var(--size)/4.2);font-weight:600}
.mf-portal .ring .val small{font-size:.5em;font-weight:500;color:var(--sub)}
.mf-portal .ring.st-good{background:conic-gradient(#2f7d4f calc(var(--p)*1%), var(--track) 0)}
.mf-portal .ring.st-warn{background:conic-gradient(#b7791f calc(var(--p)*1%), var(--track) 0)}
.mf-portal .ring.st-bad{background:conic-gradient(#b3382f calc(var(--p)*1%), var(--track) 0)}
.mf-portal .ring.na{background:var(--track)}
.mf-portal .ring.na .val{color:var(--faint)}
.mf-portal .mc-right .ring::before,.mf-portal .staff-card .ring::before{background:var(--card)}

/* ── 総括ストリップ ── */
.mf-portal .summary{display:flex;align-items:center;gap:28px;border-top:1px solid var(--ink);border-bottom:1px solid var(--line);padding:24px 0;margin-bottom:30px}
.mf-portal .summary .s-meta .l{font-size:11px;letter-spacing:.26em;color:var(--faint);text-transform:uppercase}
.mf-portal .summary .s-meta .big{font-size:22px;font-weight:600;margin-top:6px}
.mf-portal .summary .s-meta .sub{font-size:12px;color:var(--sub);margin-top:4px}

/* ── 終了条件（決めること）リスト ── */
.mf-portal .hint{font-size:11px;color:var(--faint)}
.mf-portal .objlist{display:grid;gap:7px;margin-bottom:10px}
.mf-portal .obj-row{display:flex;align-items:center;gap:10px}
.mf-portal .obj-no{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--chip);color:var(--sub);font-size:11px;display:grid;place-items:center}
.mf-portal .obj-del,.mf-portal .ev-item .obj-del{flex:0 0 auto;border:0;background:transparent;color:var(--faint);font-size:17px;cursor:pointer;line-height:1}
.mf-portal .obj-del:hover{color:var(--bad)}

/* 報告フォームの「決めること」想起 */
.mf-portal .obj-recall{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--ink);padding:13px 18px;margin-bottom:18px}
.mf-portal .or-l{font-size:11px;letter-spacing:.1em;color:var(--faint);text-transform:uppercase;margin-bottom:8px}
.mf-portal .obj-recall ol{margin:0;padding-left:20px;font-size:13px;color:var(--ink-2);line-height:1.9}

/* ── 履歴カード右側 ── */
.mf-portal .mc-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
.mf-portal .mc-tag{font-size:10px;color:var(--sub);background:var(--chip);border-radius:99px;padding:2px 9px}
.mf-portal .mc-wait{font-size:11px;color:var(--warn);white-space:nowrap}
.mf-portal .btn-fill.sm{padding:6px 14px;font-size:11.5px;text-decoration:none}
.mf-portal .badge.b-rejected{background:#fbecec;color:#a3382f;border:1px solid #ecc9c6}
.mf-portal .badge.b-reported{background:#eef2f7;color:#3a5a85;border:1px solid #cdd9e6}
.mf-portal .badge.b-evaluated{background:#eef6f1;color:#2f7d4f;border:1px solid #cfe6da}
.mf-portal .mf-card.st-rejected{border-left-color:var(--bad)}
.mf-portal .mf-card.st-reported{border-left-color:#3a5a85}
.mf-portal .mf-card.st-evaluated{border-left-color:var(--ok)}

/* ── 評価画面 ── */
.mf-portal .ev-report{background:var(--card);border:1px solid var(--line);padding:16px 18px;margin-bottom:18px}
.mf-portal .ev-decisions{font-size:13px;color:var(--ink-2);line-height:1.8;white-space:pre-wrap;margin-top:6px}
.mf-portal .ev-grid{display:grid;grid-template-columns:1fr 220px;gap:26px;align-items:start}
.mf-portal .ev-items{display:grid;gap:7px;margin:10px 0}
.mf-portal .ev-item{display:flex;align-items:center;gap:10px}
.mf-portal .ev-item .ev-chk{width:18px;height:18px;accent-color:var(--ink);flex:0 0 auto}
.mf-portal .ev-item .ev-text{flex:1}
.mf-portal .ev-right{position:sticky;top:64px;display:flex;flex-direction:column;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);padding:22px 18px}
.mf-portal .ev-pct-l{font-size:11px;letter-spacing:.2em;color:var(--faint);text-transform:uppercase;margin-top:-4px}
.mf-portal .ev-right .btn-fill{width:100%}

/* ── 社員一覧 ── */
.mf-portal .staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.mf-portal .staff-card{display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--line);padding:16px 18px;text-decoration:none;color:var(--ink);transition:border-color .15s}
.mf-portal .staff-card:hover{border-color:var(--ink)}
.mf-portal .sc-name{font-size:14px;font-weight:600}
.mf-portal .sc-sub{font-size:11px;color:var(--sub);margin-top:3px}
.mf-portal .backlink{margin:18px 0 -10px}
.mf-portal .backlink a{font-size:12px;color:var(--sub);text-decoration:none}
.mf-portal .backlink a:hover{color:var(--ink)}

/* 印刷シート：終了条件チェック・評価 */
.mf-sheet .sh-obj{margin:0;padding-left:22px;font-size:13px;line-height:2}
.mf-sheet .sh-obj .ok{color:#2f7d4f;font-weight:600;font-size:11px}
.mf-sheet .sh-obj .ng{color:#b3382f;font-weight:600;font-size:11px}
.mf-sheet .sh-eval{display:flex;align-items:center;gap:20px;border:1px solid #e7e6e2;padding:16px 18px}
.mf-sheet .sh-eval .ring{--size:88px;width:88px;height:88px;border-radius:50%;background:conic-gradient(#181818 calc(var(--p)*1%),#ececea 0);display:grid;place-items:center;position:relative;flex:0 0 auto}
.mf-sheet .sh-eval .ring::before{content:"";position:absolute;inset:10px;border-radius:50%;background:#fff}
.mf-sheet .sh-eval .ring .val{position:relative;font-size:20px;font-weight:600}
.mf-sheet .sh-eval .ring .val small{font-size:11px;color:#7a7873}
.mf-sheet .sh-eval-c{font-size:13px;line-height:1.7;white-space:pre-wrap}

/* ── レスポンシブ ── */
@media (max-width:640px){
  .mf-portal .ev-grid{grid-template-columns:1fr}
  .mf-portal .ev-right{position:static}
  .mf-portal .staff-grid{grid-template-columns:1fr}
  .mf-portal .summary{gap:18px}
  .mf-portal .wrap{padding:0 16px}
  .mf-portal .grid2,.mf-portal .grid3{grid-template-columns:1fr;gap:14px}
  .mf-portal .ag-head{display:none}
  .mf-portal .ag-row{grid-template-columns:1fr 1fr 70px 30px}
  .mf-portal .mf-card{flex-direction:column;align-items:flex-start}
  .mf-portal .mc-act{width:100%}
  .mf-sheet{padding:24px 18px}
  .mf-sheet .sh-table th{width:74px}
}
