/* イズミクス材料受発注DX — 共通スタイル（モックアップ 共通標準UI v1.2 のデザイントークン準拠） */
:root{
  --navy:#1B3566;--navy-d:#122650;--navy-l:#EEF2F8;--navy-ll:#F7F9FC;
  --blue:#2E6DB4;--blue-l:#E8F0FB;--blue-ll:#F4F7FD;
  --teal:#1A7A52;--teal-l:#E8F5EE;
  --green:#18A058;--green-l:#E6F5EC;
  --red:#D63031;--red-l:#FDEDEB;
  --amber:#D97706;--amber-l:#FEF3C7;
  --border:#DDE4EE;--bg:#FFFFFF;--bg2:#F7F9FC;--text:#1A2535;--muted:#5A6880;--wh:#fff;
}
/* ロール別テーマ色（ブランドの navy 系のみ上書き＝ヘッダー/サイドバー/主ボタン/見出しに反映。
   意味色〔ステータスバッジ等〕は据え置き）。職人・協力会社＝落ち着いたグリーン／仕入先・ドライバー＝落ち着いたオレンジ。 */
.theme-green{--navy:#2F6A4F;--navy-d:#235540;--navy-l:#E7F2EB;--navy-ll:#F3F9F5}
.theme-green .nav-i.act{background:var(--navy-l);border-left-color:var(--navy);color:var(--navy)}
.theme-orange{--navy:#B5651D;--navy-d:#8F4F16;--navy-l:#FAEEE1;--navy-ll:#FDF8F2}
.theme-orange .nav-i.act{background:var(--navy-l);border-left-color:var(--navy);color:var(--navy)}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:'Noto Sans JP',sans-serif;background:var(--bg2);color:var(--text);font-size:15px}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* レイアウト（濃紺ヘッダー＋サイドバー） */
.app{display:grid;grid-template-rows:54px 1fr;grid-template-columns:230px 1fr;grid-template-areas:"head head" "side main";min-height:100%}
.topbar{grid-area:head;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 18px}
.topbar .brand{font-weight:800;font-size:16px;letter-spacing:.02em}
.topbar .user{display:flex;align-items:center;gap:12px;font-size:14px}
.topbar .user .logout{background:var(--navy-d);color:#fff;border:none;border-radius:7px;padding:6px 12px;font-size:14px}
.side{grid-area:side;background:var(--wh);border-right:1px solid var(--border);padding:16px 0;overflow-y:auto}
.nav-ttl{font-size:13px;font-weight:700;padding:0 20px 6px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.nav-i{display:block;padding:9px 20px;color:var(--text);font-size:15px;border-left:3px solid transparent}
.nav-i:hover{background:var(--navy-ll)}
.nav-i.act{background:var(--blue-ll);border-left-color:var(--blue);font-weight:700;color:var(--navy)}
.main{grid-area:main;padding:22px 26px;overflow-y:auto}

/* 見出し */
.page-h{font-size:20px;font-weight:800;color:var(--navy);margin-bottom:4px}
.page-sub{font-size:14px;color:var(--muted);margin-bottom:18px}

/* カード／KPI（モックアップ標準UI: 上ボーダー色アクセント＋数値＋説明の3層） */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;margin-bottom:18px}
.card{background:var(--wh);border:1px solid var(--border);border-radius:14px;padding:16px 18px;box-shadow:0 1px 4px rgba(20,40,80,.05)}
.kpi{border-top:4px solid var(--border)}
.kpi.top-red{border-top-color:var(--red)}.kpi.top-amber{border-top-color:var(--amber)}
.kpi.top-blue{border-top-color:var(--blue)}.kpi.top-navy{border-top-color:var(--navy)}
.kpi .kpi-label{font-size:14px;color:var(--muted);margin-bottom:8px;font-weight:600}
.kpi .kpi-value{font-size:32px;font-weight:800;color:var(--navy);line-height:1;font-variant-numeric:tabular-nums}
.kpi .kpi-value.v-red{color:var(--red)}.kpi .kpi-value.v-amber{color:var(--amber)}.kpi .kpi-value.v-blue{color:var(--blue)}
.kpi.alert.zero .kpi-value{color:var(--navy)}
.kpi.alert.zero{border-top-color:var(--border)}
a.kpi{text-decoration:none;color:inherit;cursor:pointer;transition:box-shadow .12s,transform .12s}
a.kpi:hover{box-shadow:0 5px 16px rgba(20,40,80,.12);transform:translateY(-2px)}
.pulse-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--red);margin-left:6px;vertical-align:middle;animation:pulse 1.5s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(214,48,49,.5)}70%{box-shadow:0 0 0 7px rgba(214,48,49,0)}100%{box-shadow:0 0 0 0 rgba(214,48,49,0)}}

/* バッジ */
.badge{display:inline-block;padding:3px 9px;border-radius:999px;font-size:13px;font-weight:700}
.c-ok{background:var(--green-l);color:var(--teal)}.c-w{background:var(--amber-l);color:var(--amber)}
.c-b{background:var(--blue-l);color:var(--blue)}.c-n{background:var(--navy-l);color:var(--navy)}
.c-e{background:var(--red-l);color:var(--red)}.c-g{background:var(--bg2);color:var(--muted);border:1px solid var(--border)}

/* ボタン（手本: 太字700・角丸8px・トランジション。フォントは15px維持） */
.btn{border:1.5px solid var(--border);background:var(--wh);border-radius:8px;padding:8px 16px;font-size:15px;font-weight:700;transition:all .12s}
.btn:hover{background:var(--bg2)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}.btn-navy:hover{background:var(--navy-d)}
.btn-blue{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-blue:hover{opacity:.9;background:var(--blue)}

/* テーブル */
.tbl{width:100%;border-collapse:collapse;background:var(--wh);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 1px 4px rgba(20,40,80,.05)}
.tbl th{background:var(--navy-ll);text-align:left;padding:10px 14px;font-size:14px;color:var(--muted);font-weight:700;border-bottom:1px solid var(--border)}
.tbl td{padding:11px 14px;font-size:15px;border-bottom:1px solid var(--border)}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--navy-ll)}

/* フォーム */
.fg{margin-bottom:14px}
.fg label{display:block;font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px}
.fg input,.fg select{width:100%;border:1.5px solid var(--border);border-radius:9px;padding:9px 12px;font-size:15px;font-family:inherit;color:var(--text);background:var(--wh);outline:none;transition:border-color .15s}
.fg input:focus,.fg select:focus{border-color:var(--blue)}

/* ログイン */
.login-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{width:360px;background:var(--wh);border:1px solid var(--border);border-radius:16px;padding:30px 28px;box-shadow:0 8px 30px rgba(27,53,102,.07)}
.login-brand{font-size:22px;font-weight:800;color:var(--navy);text-align:center;margin-bottom:6px}
.login-sub{font-size:14px;color:var(--muted);text-align:center;margin-bottom:22px}

/* 情報バナー／空状態／エラー */
.info-banner{display:block;background:var(--blue-ll);border:1px solid var(--blue-l);border-radius:10px;padding:10px 12px;font-size:14px;color:var(--navy);line-height:1.7;margin-bottom:14px}
.banner-error{background:var(--red-l);border-color:var(--red-l);color:var(--red)}
.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.err-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px}
.err-code{font-size:15px;font-weight:800;letter-spacing:.14em;color:var(--muted);margin-bottom:10px}
.err-ttl{font-size:23px;font-weight:800;color:var(--navy);margin-bottom:12px}
.err-msg{font-size:15px;color:var(--muted);margin-bottom:20px}

/* トースト */
#toast{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:8px;z-index:50}
.toast{background:var(--wh);border:1px solid var(--border);border-left:4px solid var(--blue);border-radius:10px;padding:12px 16px;font-size:15px;box-shadow:0 6px 22px rgba(27,53,102,.12)}
.toast.ok{border-left-color:var(--green)}.toast.err{border-left-color:var(--red)}

/* ヘッダーのアイコンメニュー（ベル通知・人型アカウントメニュー） */
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;color:#fff;background:rgba(255,255,255,.12);border:none;cursor:pointer;transition:background .15s}
.icon-btn:hover{background:rgba(255,255,255,.24)}
.menu-wrap{position:relative}
.menu-pop{position:absolute;right:0;top:calc(100% + 8px);background:var(--wh);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 26px rgba(27,53,102,.16);min-width:220px;padding:6px;z-index:80}
.menu-pop .menu-user{padding:9px 12px 8px;font-weight:700;font-size:13px;color:var(--muted);border-bottom:1px solid var(--border);margin-bottom:4px;white-space:nowrap}
.menu-pop a,.menu-pop button{display:block;width:100%;text-align:left;padding:9px 12px;border:none;border-radius:7px;background:none;color:var(--text);font-size:14px;font-weight:600;cursor:pointer}
.menu-pop a:hover,.menu-pop button:hover{background:var(--navy-ll)}
.menu-pop .menu-danger{color:var(--red)}

/* ページャ */
.pager{display:flex;gap:8px;align-items:center;justify-content:flex-end;margin-top:14px;font-size:14px;color:var(--muted)}

/* スマートフォン（職人・ドライバー） */
.mobile{max-width:460px;margin:0 auto;min-height:100%;background:var(--bg2)}
.mobile-head{background:var(--navy);color:#fff;padding:14px 16px;font-weight:800;position:sticky;top:0}
.mobile-body{padding:16px}
.mobile-card{background:var(--wh);border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:12px;box-shadow:0 1px 4px rgba(20,40,80,.05)}
