/* RiD Meeting Flow Lite — 会議報告ポータル（白黒・マットブラック）
   方針：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}
.ml-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;
}
.ml-portal .wrap{max-width:920px;margin:0 auto;padding:0 28px;width:100%}
.ml-portal main.wrap{flex:1}

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

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

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

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

/* フラッシュ */
.ml-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)}
.ml-portal .flash.ok{border-left-color:var(--ok)}
.ml-portal .flash.ng{border-left-color:var(--bad);color:#7a2a24}
.ml-portal .flash.warn{border-left-color:var(--warn);background:#fdfaf2}

/* フォーム */
.ml-portal .ml-form{margin-top:8px;padding-bottom:56px}
.ml-portal .fset{margin:0 0 18px}
.ml-portal .fl{display:block;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--ink-2);margin-bottom:7px}
.ml-portal .fl.req::after{content:'＊';color:var(--bad);margin-left:4px;font-weight:700}
.ml-portal .fl-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:7px}
.ml-portal .fl-row .fl{margin-bottom:0}
.ml-portal .hint{font-size:11px;color:var(--faint)}
.ml-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}
.ml-portal .fi:focus{outline:none;border-color:var(--ink)}
.ml-portal textarea.fi{resize:vertical;line-height:1.6}
.ml-portal .fi.readonly{background:#f7f6f3;display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.ml-portal .ro-note{font-size:11px;color:var(--faint);font-weight:400}
.ml-portal .grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ml-portal .grid4{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:14px}
.ml-portal .ml-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* 終了条件リスト */
.ml-portal .objlist{display:grid;gap:7px;margin-bottom:10px}
.ml-portal .obj-row{display:flex;align-items:center;gap:10px}
.ml-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}
.ml-portal .obj-del,.ml-portal .ag-del{flex:0 0 auto;border:0;background:transparent;color:var(--faint);font-size:17px;cursor:pointer;line-height:1}
.ml-portal .obj-del:hover,.ml-portal .ag-del:hover{color:var(--bad)}

/* 進行内容（議題・求める結果） */
.ml-portal .agenda{border:1px solid var(--line);background:var(--card);border-radius:2px;overflow:hidden}
.ml-portal .ag-head,.ml-portal .ag-row{display:grid;grid-template-columns:1fr 1.3fr 34px;align-items:center}
.ml-portal .ag-head{background:#f7f6f3;border-bottom:1px solid var(--line);font-size:11px;color:var(--sub)}
.ml-portal .ag-head span{padding:9px 12px}
.ml-portal .ag-row{border-bottom:1px solid var(--line-2)}
.ml-portal .ag-row:last-child{border-bottom:0}
.ml-portal .ag-row .fi{border:0;border-right:1px solid var(--line-2);border-radius:0;background:transparent}
.ml-portal .ag-row .fi:focus{background:#fcfcfa;box-shadow:inset 0 0 0 1px var(--ink)}
.ml-portal #ag-add,.ml-portal #obj-add{margin-top:10px}

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

/* ボタン */
.ml-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;text-decoration:none;transition:.15s}
.ml-portal .btn-fill:hover{background:#000}
.ml-portal .btn-fill.sm{padding:6px 14px;font-size:11.5px}
.ml-portal .btn-fill:disabled{opacity:.5;cursor:default}
.ml-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}
.ml-portal .btn-line:hover{border-color:var(--ink)}
.ml-portal .btn-line.sm{padding:5px 12px;font-size:11.5px}
.ml-portal .btn-line.danger:hover{border-color:var(--bad);color:var(--bad)}
.ml-portal .ml-actions{display:flex;align-items:center;gap:16px;margin-top:30px;padding-top:24px;border-top:1px solid var(--ink);flex-wrap:wrap}
.ml-portal .ml-note{font-size:11.5px;color:var(--faint)}

/* 一覧 */
.ml-portal .empty{padding:40px;text-align:center;color:var(--faint);border:1px dashed var(--line);background:var(--card);font-size:13px}
.ml-portal .ml-list{display:grid;gap:8px}
.ml-portal .ml-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}
.ml-portal .ml-card.st-planned{border-left-color:var(--warn)}
.ml-portal .ml-card.st-reported{border-left-color:var(--ok)}
.ml-portal .ml-card.st-canceled{opacity:.6}
.ml-portal .mc-top{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.ml-portal .mc-title{font-size:14.5px;font-weight:600}
.ml-portal .mc-meta{display:flex;gap:14px;font-size:11.5px;color:var(--sub);flex-wrap:wrap}
.ml-portal .mc-err{color:var(--bad)}
.ml-portal .mc-act{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}
.ml-portal .badge{display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.06em;padding:3px 11px;border-radius:99px;white-space:nowrap}
.ml-portal .b-planned{background:#fdfaf2;color:var(--warn);border:1px solid #e3d9c2}
.ml-portal .b-reported{background:#eef6f1;color:var(--ok);border:1px solid #cfe6da}
.ml-portal .b-canceled{background:var(--chip);color:var(--faint);border:1px solid var(--line)}

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

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

/* ログイン */
.ml-login-page{justify-content:center;align-items:center}
.ml-portal.ml-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}
.ml-login-page .login-card label{display:block;font-size:12px;color:var(--ink-2);margin-bottom:14px;font-weight:600}
.ml-login-page .login-card input[type=text],.ml-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}
.ml-login-page .login-card input:focus{outline:none;border-color:var(--ink)}
.ml-login-page .login-card .button,.ml-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}
.ml-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}

/* 印刷シート */
.ml-sheet-body{background:#f0efec;margin:0;font-family:-apple-system,"Hiragino Sans","Noto Sans JP",sans-serif;color:#181818}
.ml-sheet{max-width:760px;margin:30px auto;background:#fff;border:1px solid #e7e6e2;padding:44px 48px}
.ml-sheet .sh-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid #181818;padding-bottom:16px;margin-bottom:22px}
.ml-sheet .sh-eyebrow{font-size:10px;letter-spacing:.3em;color:#a8a6a0;text-transform:uppercase;margin-bottom:6px}
.ml-sheet h1{font-size:23px;font-weight:600;letter-spacing:.04em}
.ml-sheet .sh-status{align-self:center}
.ml-sheet table{width:100%;border-collapse:collapse;font-size:13px}
.ml-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}
.ml-sheet .sh-table td{border:1px solid #e7e6e2;padding:9px 12px;vertical-align:top}
.ml-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}
.ml-sheet .sh-obj{margin:0;padding-left:22px;font-size:13px;line-height:2}
.ml-sheet .sh-agenda th{background:#181818;color:#fff;border:1px solid #181818;padding:8px 12px;font-weight:600;text-align:left}
.ml-sheet .sh-agenda td{border:1px solid #e7e6e2;padding:8px 12px;vertical-align:top}
.ml-sheet .sh-agenda .c-no{width:40px;text-align:center;color:#7a7873}
.ml-sheet .sh-box{border:1px solid #e7e6e2;padding:12px 14px;font-size:13px;min-height:48px;line-height:1.7;white-space:pre-wrap}
.ml-sheet .dim{color:#a8a6a0;text-align:center}
.ml-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}
.ml-sheet .sh-print{margin-top:22px;text-align:center}
.ml-sheet .badge{display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.06em;padding:3px 11px;border-radius:99px}
.ml-sheet .b-planned{background:#fdfaf2;color:#9c6a12;border:1px solid #e3d9c2}
.ml-sheet .b-reported{background:#eef6f1;color:#2f7d4f;border:1px solid #cfe6da}
.ml-sheet .b-canceled{background:#f3f2ee;color:#a8a6a0;border:1px solid #e7e6e2}
.ml-sheet .btn-fill{display:inline-block;font-size:14px;font-weight:600;color:#fff;background:#181818;border:1px solid #181818;padding:11px 28px;border-radius:2px;cursor:pointer}
@media print{ .ml-sheet-body{background:#fff} .ml-sheet{margin:0;border:0;padding:0;max-width:none} .sh-print{display:none!important} }

/* レスポンシブ */
@media (max-width:640px){
  .ml-portal .wrap{padding:0 16px}
  .ml-portal .grid2,.ml-portal .grid4{grid-template-columns:1fr;gap:14px}
  .ml-portal .ag-head{display:none}
  .ml-portal .ag-row{grid-template-columns:1fr 1fr 30px}
  .ml-portal .ml-card{flex-direction:column;align-items:flex-start}
  .ml-portal .staff-grid{grid-template-columns:1fr}
  .ml-sheet{padding:24px 18px}
}
