/* ===== RENTALink 管理者ポータル UIサンプル 共通CSS ===== */
:root{
  --ink:#18222e; --sub:#62707e; --accent:#1f4e79; --accent2:#0e7c7b;
  --line:#dde3ea; --soft:#eef2f6; --bg:#f4f7fa; --gold:#b8893a; --ok:#2e7d52; --danger:#b0473a; --warn:#c46a1f;
  --rental:#1f4e79; --moving:#0e7c7b; --ihin:#6a55a0; --goods:#c46a1f;
  --side:#16314c;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family:"Yu Gothic","Hiragino Kaku Gothic ProN","Meiryo",sans-serif;font-size:13px;line-height:1.5;
  -webkit-print-color-adjust:exact;print-color-adjust:exact;}
a{color:inherit;text-decoration:none;}

/* レイアウト */
.app{display:grid;grid-template-columns:212px 1fr;min-height:100vh;}
.side{background:var(--side);color:#cdd9e6;padding:0;}
.side .brand{padding:15px 16px;font-size:17px;font-weight:bold;color:#fff;border-bottom:1px solid rgba(255,255,255,.12);letter-spacing:.5px;}
.side .brand small{display:block;font-size:9.5px;color:#8fa6bd;font-weight:normal;letter-spacing:1px;margin-top:2px;}
.side .navsec{font-size:10px;color:#7e95ac;padding:12px 16px 4px;letter-spacing:1px;}
.side nav a{display:flex;align-items:center;gap:9px;padding:8px 16px;font-size:12.5px;color:#cdd9e6;border-left:3px solid transparent;}
.side nav a .ic{width:16px;text-align:center;opacity:.85;}
.side nav a:hover{background:rgba(255,255,255,.06);}
.side nav a.on{background:rgba(255,255,255,.10);border-left-color:var(--accent2);color:#fff;font-weight:bold;}

.main{display:flex;flex-direction:column;min-height:100vh;}
.top{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid var(--line);padding:9px 18px;}
.top .crumb{font-size:13px;color:var(--sub);} .top .crumb b{color:var(--ink);font-size:15px;}
.top .right{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--sub);}
.top .right .u{display:flex;align-items:center;gap:7px;}
.top .avatar{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:bold;}
.content{padding:16px 18px;flex:1;}
.pagehd{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px;}
.pagehd h1{font-size:18px;margin:0;color:var(--ink);}
.pagehd .desc{font-size:11.5px;color:var(--sub);}

/* 部品 */
.row{display:flex;gap:12px;flex-wrap:wrap;}
.cards{display:grid;gap:12px;}
.k4{grid-template-columns:repeat(4,1fr);} .k3{grid-template-columns:repeat(3,1fr);} .k2{grid-template-columns:1fr 1fr;}
.card{background:#fff;border:1px solid var(--line);border-radius:9px;padding:13px 15px;}
.card.kpi{border-top:3px solid var(--accent);}
.card .lab{font-size:11px;color:var(--sub);} .card .val{font-size:23px;font-weight:bold;color:var(--ink);margin-top:3px;}
.card .delta{font-size:11px;margin-top:2px;} .up{color:var(--ok);} .down{color:var(--danger);}
.card h2{font-size:14px;margin:0 0 9px;color:var(--accent);display:flex;justify-content:space-between;align-items:center;}
.card h2 .more{font-size:11px;color:var(--accent2);font-weight:normal;}

.panel{background:#fff;border:1px solid var(--line);border-radius:9px;overflow:hidden;}
.panel .ph{padding:10px 15px;border-bottom:1px solid var(--line);font-weight:bold;color:var(--accent);font-size:13.5px;display:flex;justify-content:space-between;align-items:center;}
.panel .pb{padding:13px 15px;}

table{width:100%;border-collapse:collapse;font-size:12px;}
th,td{text-align:left;padding:8px 11px;border-bottom:1px solid var(--line);}
th{background:#f7fafc;color:var(--sub);font-weight:bold;font-size:11px;}
tr:hover td{background:#f9fcff;}

.badge{display:inline-block;font-size:10.5px;font-weight:bold;padding:2px 9px;border-radius:11px;}
.b-ok{background:#e3f2e9;color:var(--ok);} .b-wait{background:#fdf3e3;color:var(--warn);} .b-ng{background:#fbe9e6;color:var(--danger);}
.b-info{background:#e7eef6;color:var(--accent);} .b-mut{background:#eef1f4;color:var(--sub);}
.chip{display:inline-block;font-size:10px;font-weight:bold;padding:1px 8px;border-radius:10px;color:#fff;}
.c-rental{background:var(--rental);}.c-moving{background:var(--moving);}.c-ihin{background:var(--ihin);}.c-goods{background:var(--goods);}

.btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:bold;padding:7px 14px;border-radius:7px;border:1px solid var(--accent);background:var(--accent);color:#fff;cursor:pointer;}
.btn.ghost{background:#fff;color:var(--accent);} .btn.ok{background:var(--ok);border-color:var(--ok);} .btn.warn{background:var(--warn);border-color:var(--warn);}
.btn.sm{font-size:11px;padding:4px 10px;}

.form-row{display:grid;grid-template-columns:130px 1fr;gap:10px;align-items:center;margin-bottom:9px;}
.form-row label{font-size:12px;color:var(--sub);} .req{color:var(--danger);font-size:10px;}
.inp{width:100%;border:1px solid var(--line);border-radius:6px;padding:7px 9px;font-size:12.5px;background:#fff;}
.inp.ro{background:#f6f8fa;color:var(--ink);}
.help{font-size:10.5px;color:var(--sub);margin-top:2px;}

/* API操作パネル */
.api{border:1px dashed var(--accent2);border-radius:8px;padding:10px 13px;background:#f0f8f8;}
.api .at{font-size:12px;font-weight:bold;color:var(--accent2);margin-bottom:6px;}
.api .arow{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;padding:4px 0;border-bottom:1px dotted var(--line);}
.api .arow:last-child{border-bottom:none;}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:5px;} .d-on{background:var(--ok);} .d-off{background:#c3ccd5;}

.tag-note{font-size:10.5px;color:var(--sub);background:#fff8ec;border:1px solid #ecd9b3;border-radius:6px;padding:7px 10px;margin-top:10px;}
.mini{font-size:10.5px;color:var(--sub);}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}
.cal .d{border:1px solid var(--line);border-radius:6px;min-height:64px;padding:5px;font-size:10px;background:#fff;}
.cal .d .dn{color:var(--sub);font-weight:bold;} .cal .ev{font-size:9.5px;border-radius:4px;padding:1px 4px;margin-top:2px;color:#fff;}

/* ===== v5：階層ナビ（折りたたみカテゴリ・全画面到達） ===== */
.side nav.navtree{padding:6px 0 22px;}
.navtree details{border:none;}
.navtree summary{list-style:none;display:flex;align-items:center;gap:9px;padding:9px 16px 7px;font-size:10.5px;color:#8fa6bd;letter-spacing:1px;cursor:pointer;font-weight:bold;user-select:none;}
.navtree summary::-webkit-details-marker{display:none;}
.navtree summary .ic{width:15px;text-align:center;opacity:.8;}
.navtree summary::after{content:"▾";margin-left:auto;font-size:9px;opacity:.65;transition:transform .15s;}
.navtree details[open] summary::after{transform:rotate(180deg);}
.navtree summary:hover{color:#cdd9e6;background:rgba(255,255,255,.04);}
.navtree a{display:flex;align-items:center;gap:9px;padding:7px 16px 7px 30px;font-size:12px;color:#cdd9e6;border-left:3px solid transparent;}
.navtree a .ic{width:15px;text-align:center;opacity:.8;font-size:11px;}
.navtree a:hover{background:rgba(255,255,255,.06);}
.navtree a.on{background:rgba(255,255,255,.10);border-left-color:var(--accent2);color:#fff;font-weight:bold;}

/* ===== v5：検索付きコンボボックス（多件数項目のプルダウン代替） ===== */
.combo{position:relative;width:100%;}
.combo .cbox{display:flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:6px;padding:6px 9px;background:#fff;cursor:text;font-size:12.5px;min-height:33px;}
.combo .cbox:focus{outline:2px solid var(--accent2);outline-offset:-1px;}
.combo .cbox .ci{color:var(--accent2);font-size:12px;}
.combo .cbox .cv{font-weight:bold;color:var(--ink);}
.combo .cbox .cv.ph{font-weight:normal;color:#9aa6b1;}
.combo .cbox .cx{margin-left:auto;color:var(--sub);font-size:10px;opacity:.7;}
.combo .cpanel{display:none;position:absolute;z-index:30;left:0;right:0;top:calc(100% + 3px);background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 26px rgba(0,0,0,.14);padding:7px;max-height:248px;overflow:auto;}
.combo.open .cpanel{display:block;}
.combo .csearch{width:100%;border:1px solid var(--line);border-radius:6px;padding:6px 8px;font-size:12px;margin-bottom:6px;}
.combo .crecent{font-size:9.5px;color:var(--sub);letter-spacing:.5px;margin:2px 3px 4px;}
.combo .copt{padding:6px 8px;border-radius:5px;font-size:12px;cursor:pointer;display:flex;justify-content:space-between;gap:10px;align-items:center;}
.combo .copt:hover{background:var(--soft);}
.combo .copt.sel{background:#eef4fb;font-weight:bold;}
.combo .copt .cid{color:var(--sub);font-size:10.5px;font-variant-numeric:tabular-nums;}
.combo .copt.hide{display:none;}
.combo .cnew{border-top:1px dashed var(--line);margin-top:6px;padding-top:8px;color:var(--accent2);font-weight:bold;font-size:11.5px;cursor:pointer;display:flex;align-items:center;gap:6px;}
.combo .cnew:hover{text-decoration:underline;}
.combo .cempty{font-size:11px;color:var(--sub);padding:8px;text-align:center;display:none;}

/* ===== v5：編集／保存バー（確定前データの直接編集導線） ===== */
.editbar{display:flex;align-items:center;gap:10px;background:#eef4fb;border:1px solid #c7dcf2;border-radius:8px;padding:8px 13px;margin-bottom:12px;font-size:12px;color:var(--accent);}
.editbar .lbl{font-weight:bold;}
.editbar .sp{margin-left:auto;display:flex;gap:8px;}
.editbar.locked{background:#f1f4f7;border-color:var(--line);color:var(--sub);}
.editbar .pill{font-size:10px;font-weight:bold;padding:1px 8px;border-radius:9px;background:#fff;border:1px solid currentColor;}

/* 備考（自由記述）textarea */
textarea.inp{width:100%;border:1px solid var(--line);border-radius:6px;padding:7px 9px;font-size:12.5px;background:#fff;font-family:inherit;line-height:1.55;resize:vertical;}
.remark{background:#fcfdff;}

/* ===== v2.3：業務フローバー（受注〜入金〜在庫復帰の現在地表示） ===== */
.flowstrip{display:flex;align-items:center;gap:3px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:9px;padding:7px 13px;margin:0 0 13px;font-size:11px;}
.flowstrip .fsl{font-size:9.5px;font-weight:bold;color:var(--sub);letter-spacing:1px;margin-right:7px;}
.flowstrip .fs{display:inline-block;padding:3px 10px;border-radius:12px;color:var(--sub);background:#f1f4f7;font-weight:bold;white-space:nowrap;}
.flowstrip .fs:hover{background:#e3ebf2;color:var(--accent);}
.flowstrip .fs.done{background:#e3f2e9;color:var(--ok);}
.flowstrip .fs.on{background:var(--accent);color:#fff;box-shadow:0 2px 6px rgba(31,78,121,.25);}
.flowstrip .fsar{color:#b6c2cd;font-weight:bold;padding:0 1px;}

/* ===== v2.3：横断クイック検索（トップバー） ===== */
.qsearch{display:flex;align-items:center;gap:6px;background:#f4f7fa;border:1px solid var(--line);border-radius:16px;padding:4px 12px;}
.qsearch input{border:none;background:transparent;outline:none;font-size:11.5px;width:230px;font-family:inherit;color:var(--ink);}
.qsearch input::placeholder{color:#9aa6b1;}
