/* ============================================================
   NEXUS — Hybrid design system (Warm Paper base + dense data)
   Mobile-first. Desktop enhancements via @media (min-width:1000px)
   ============================================================ */
:root{
  --bg:#FAF8F3; --surface:#FFFEFB; --raised:#F4F1E9; --raised2:#EFEBE1;
  --line:#EAE4D8; --line-soft:#F1EDE4; --line-strong:#DED7C8;
  --ink:#23211B; --ink2:#4C473D; --muted:#7E7666; --faint:#9C947F;
  --accent:#2F5D50; --accent-d:#244A40; --accent-soft:#E6EEEA; --accent-bg:#E6EEEA; --accent-tint:#F0F4F1; --accent-fg:#FFFFFF;
  --ok:#3C6B3E; --ok-bg:#E9F0E6; --warn:#8A5709; --warn-bg:#F7EEDA;
  --danger:#9E3329; --danger-bg:#F5E5E1; --info:#345C79; --info-bg:#E6EDF2;
  --neutral:#6B6456; --neutral-bg:#F0ECE2;
  --glass:rgba(250,248,243,.86); --toast-bg:#23211B; --toast-fg:#FFFEFB; --scroll:#D8D1C2;
  --r-sm:9px; --r:13px; --r-lg:18px;
  --shadow:0 1px 2px rgba(35,33,27,.05), 0 1px 3px rgba(35,33,27,.04);
  --shadow-lg:0 4px 16px rgba(35,33,27,.10), 0 1px 3px rgba(35,33,27,.06);
  --sans:"IBM Plex Sans Thai","IBM Plex Sans",system-ui,sans-serif;
  --serif:"Noto Serif Thai","IBM Plex Serif",Georgia,serif;
  --num:"IBM Plex Sans","IBM Plex Sans Thai",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
}
/* ---------- Dark mode (warm, calm, premium) ---------- */
[data-theme="dark"]{
  --bg:#16150F; --surface:#201E16; --raised:#272419; --raised2:#2F2B1F;
  --line:#322E22; --line-soft:#272318; --line-strong:#433E2F;
  --ink:#F1ECDF; --ink2:#CBC3B0; --muted:#9A907C; --faint:#6F6857;
  --accent:#6AA793; --accent-d:#5A917F; --accent-soft:#22332C; --accent-bg:#22332C; --accent-tint:#1D2A24; --accent-fg:#16150F;
  --ok:#84C281; --ok-bg:#1E2C1D; --warn:#DDA94A; --warn-bg:#2F2614;
  --danger:#E59283; --danger-bg:#342019; --info:#88AECB; --info-bg:#1C2A33;
  --neutral:#B0A78F; --neutral-bg:#2A2619;
  --glass:rgba(22,21,15,.84); --toast-bg:#2F2B1F; --toast-fg:#F1ECDF; --scroll:#3A3526;
  --shadow:0 1px 2px rgba(0,0,0,.30), 0 1px 3px rgba(0,0,0,.24);
  --shadow-lg:0 6px 22px rgba(0,0,0,.46), 0 1px 3px rgba(0,0,0,.30);
}
html{ background:var(--bg); }
.app, .appbar, .sidebar, .bottomnav, .card, .rail-card, .proj-row, .kpi, .summary-card, .phase, .meet-card, .appr-card, .gantt-wrap, .dlog-card, .panel, .doc-card, .chip, .btn, .seg{ transition:background-color .25s ease, border-color .25s ease, color .2s ease; }
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{ font-family:var(--sans); background:var(--bg); color:var(--ink);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; font-size:16px; line-height:1.58; }
.serif{ font-family:var(--serif); }
.mono{ font-family:var(--mono); font-variant-numeric:tabular-nums; }
.tnum{ font-family:var(--num); font-variant-numeric:tabular-nums; font-feature-settings:"tnum" 1; letter-spacing:0; }
.num{ font-family:var(--num); font-variant-numeric:tabular-nums; font-feature-settings:"tnum" 1; }
button{ font-family:inherit; cursor:pointer; }
a{ color:inherit; text-decoration:none; }
::-webkit-scrollbar{ width:10px; height:10px; }
::-webkit-scrollbar-thumb{ background:var(--scroll); border-radius:99px; border:3px solid var(--bg); }

/* ---------- App shell ---------- */
#root{ min-height:100vh; }
.app{ min-height:100vh; }
.app-main{ min-width:0; }

/* top app bar (mobile + desktop) */
.appbar{ position:sticky; top:0; z-index:40; height:60px; background:var(--glass);
  backdrop-filter:saturate(140%) blur(12px); -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line); display:flex; align-items:center; gap:12px; padding:0 16px; }
.appbar .brand{ display:flex; align-items:center; gap:10px; }
.appbar .mark{ width:30px; height:30px; border-radius:8px; background:var(--accent); color:var(--accent-fg);
  display:grid; place-items:center; font-family:var(--serif); font-weight:700; font-size:16px; flex:none; }
.appbar .bn b{ font-family:var(--serif); font-size:16px; font-weight:600; letter-spacing:.01em; display:block; line-height:1.05; }
.appbar .bn small{ font-size:10.5px; color:var(--faint); }
.appbar .spacer{ flex:1; }
.icon-btn{ width:40px; height:40px; border-radius:10px; border:1px solid transparent; background:transparent;
  display:grid; place-items:center; color:var(--ink2); position:relative; }
.icon-btn:hover{ background:var(--raised); }
.icon-btn svg{ width:19px; height:19px; flex:none; }
.appbar .search svg{ width:17px; height:17px; flex:none; }
.icon-btn .dot{ position:absolute; top:9px; right:10px; width:7px; height:7px; border-radius:50%; background:var(--danger); border:2px solid var(--bg); }
.avatar{ display:inline-grid; place-items:center; border-radius:50%; font-weight:600; flex:none; background:var(--accent-soft); color:var(--accent); }

/* desktop sidebar (hidden on mobile) */
.sidebar{ display:none; }
.bottomnav{ position:fixed; bottom:0; left:0; right:0; z-index:45; height:66px; background:var(--glass);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-top:1px solid var(--line);
  display:flex; align-items:stretch; padding:0 4px; }
.bottomnav a{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px;
  min-height:44px; min-width:44px; color:var(--muted); font-size:11px; font-weight:600; padding-top:6px; }
.bottomnav a svg{ width:22px; height:22px; }
.bottomnav a.on{ color:var(--accent); }
.bottomnav a .nbadge{ position:absolute; }

/* Prototype banner — mobile-only, admin-only (render gated in JS), warm amber, dismissible */
.proto-banner{ display:none; }
@media (max-width:999px){
  .proto-banner{ display:flex; align-items:center; gap:8px; padding:7px 6px 7px 14px;
    background:var(--warn-bg); color:var(--warn); border-bottom:1px solid var(--line);
    font-size:12.5px; font-weight:600; line-height:1.35; }
  .proto-banner > span{ flex:1; }
  .proto-banner .proto-x{ flex:none; min-width:44px; min-height:44px; width:44px; height:44px;
    display:grid; place-items:center; border:0; background:none; color:var(--warn); }
  .proto-banner .proto-x svg{ width:18px; height:18px; }
}

.page{ padding:18px 16px 86px; max-width:560px; margin:0 auto; }

/* ---------- Common components ---------- */
.pill{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:600;
  padding:4px 11px; border-radius:99px; white-space:nowrap; line-height:1.5; }
.pill i{ width:6px; height:6px; border-radius:50%; flex:none; }
.pill.ok{ background:var(--ok-bg); color:var(--ok); } .pill.ok i{ background:var(--ok); }
.pill.warn{ background:var(--warn-bg); color:var(--warn); } .pill.warn i{ background:var(--warn); }
.pill.danger{ background:var(--danger-bg); color:var(--danger); } .pill.danger i{ background:var(--danger); }
.pill.info{ background:var(--info-bg); color:var(--info); } .pill.info i{ background:var(--info); }
.pill.neutral{ background:var(--neutral-bg); color:var(--neutral); } .pill.neutral i{ background:var(--neutral); }

.btn{ display:inline-flex; align-items:center; justify-content:center; gap:7px; font-size:14px; font-weight:600;
  padding:10px 16px; border-radius:10px; border:1px solid var(--line-strong); background:var(--surface); color:var(--ink2); min-height:42px; }
.btn:hover{ background:var(--raised); }
.btn.pri{ background:var(--accent); border-color:var(--accent); color:var(--accent-fg); }
.btn.pri:hover{ background:var(--accent-d); }
.btn.sm{ padding:7px 12px; font-size:13px; min-height:36px; border-radius:8px; }
.btn.danger{ color:var(--danger); border-color:var(--line-strong); }
.btn svg{ width:15px; height:15px; }

.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow); }
.card-pad{ padding:18px; }

.prog-bar{ height:7px; border-radius:99px; background:var(--line-strong); overflow:hidden; }
.prog-bar > i{ display:block; height:100%; border-radius:99px; background:var(--accent); }
.prog-bar.thin{ height:5px; }

.avatar.sm{ width:28px; height:28px; font-size:11px; }
.avatar.md{ width:34px; height:34px; font-size:12px; }
.avatar.lg{ width:42px; height:42px; font-size:14px; }

.eyebrow{ font-size:12px; font-weight:700; letter-spacing:.09em; text-transform:uppercase; color:var(--accent); }
.page-title{ font-family:var(--serif); font-size:28px; font-weight:600; letter-spacing:-.01em; line-height:1.2; }
.page-sub{ color:var(--muted); font-size:14.5px; margin-top:6px; line-height:1.5; }
.sec-title{ font-family:var(--serif); font-size:20px; font-weight:600; }
.divider{ height:1px; background:var(--line); border:0; }
.chip{ display:inline-flex; align-items:center; gap:6px; font-size:13.5px; font-weight:500; color:var(--ink2);
  background:var(--surface); border:1px solid var(--line-strong); border-radius:9px; padding:7px 12px; min-height:40px; }
.chip svg{ width:15px; height:15px; color:var(--muted); }
.chip.act{ color:var(--accent); border-color:var(--accent-soft); background:var(--accent-tint); }
.chip.act svg{ color:var(--accent); }

.empty{ color:var(--faint); font-size:14px; text-align:center; padding:24px; }

/* rich empty state */
.empty-state{ display:flex; flex-direction:column; align-items:center; text-align:center;
  padding:48px 24px; background:var(--surface); border:1px dashed var(--line-strong); border-radius:var(--r-lg); }
.empty-ic{ width:64px; height:64px; border-radius:18px; background:var(--raised); color:var(--faint);
  display:grid; place-items:center; margin-bottom:16px; }
.empty-ic svg{ width:30px; height:30px; }
.empty-title{ font-family:var(--serif); font-size:18px; font-weight:600; color:var(--ink2); }
.empty-sub{ font-size:13.5px; color:var(--muted); margin-top:7px; max-width:340px; line-height:1.55; }

/* error boundary card */
.err-card{ max-width:440px; margin:40px auto; text-align:center; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow); padding:42px 28px; }
.err-ic{ width:62px; height:62px; border-radius:17px; background:var(--danger-bg); color:var(--danger);
  display:grid; place-items:center; margin:0 auto 16px; }
.err-ic svg{ width:28px; height:28px; }
.err-title{ font-family:var(--serif); font-size:21px; font-weight:600; color:var(--ink); }
.err-sub{ font-size:13.5px; color:var(--muted); margin-top:9px; line-height:1.6; }
.err-acts{ display:flex; gap:10px; justify-content:center; margin-top:22px; flex-wrap:wrap; }

/* skeleton page loader */
.sk{ position:relative; overflow:hidden; background:var(--raised2); border-radius:7px; }
.sk::after{ content:""; position:absolute; inset:0; transform:translateX(-100%);
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.5), transparent); animation:sk-shimmer 1.4s infinite; }
[data-theme="dark"] .sk::after{ background:linear-gradient(90deg, transparent, rgba(255,255,255,.07), transparent); }
@keyframes sk-shimmer{ to{ transform:translateX(100%); } }
@media (prefers-reduced-motion: reduce){ .sk::after{ animation:none; } }
.sk-eyebrow{ width:96px; height:13px; }
.sk-title{ width:min(260px,70%); height:30px; margin-top:12px; }
.sk-sub{ width:min(210px,55%); height:15px; margin-top:12px; margin-bottom:26px; }
.sk-cards{ display:flex; flex-direction:column; gap:12px; }
.sk-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow); padding:16px 18px; }
.sk-line{ height:14px; margin-bottom:9px; }
.sk-line.w40{ width:40%; } .sk-line.w50{ width:50%; } .sk-line.w60{ width:60%; }
.sk-line.w70{ width:70%; } .sk-line.w80{ width:80%; } .sk-line.w90{ width:90%; }
.sk-bar{ height:7px; width:100%; margin-top:13px; }

/* ---------- Desktop layout ---------- */
@media (min-width:1000px){
  .app{ display:grid; grid-template-columns:248px 1fr; }
  .sidebar{ display:flex; flex-direction:column; position:sticky; top:0; height:100vh;
    background:var(--bg); border-right:1px solid var(--line); padding:16px 13px; overflow-y:auto; }
  .sidebar .brand{ display:flex; align-items:center; gap:11px; padding:6px 8px 14px; }
  .sidebar .mark{ width:32px; height:32px; border-radius:9px; background:var(--accent); color:var(--accent-fg);
    display:grid; place-items:center; font-family:var(--serif); font-weight:700; font-size:17px; }
  .sidebar .bn b{ font-family:var(--serif); font-size:17px; font-weight:600; display:block; line-height:1.05; }
  .sidebar .bn small{ font-size:10.5px; color:var(--faint); }
  .sidebar .grp{ font-size:10.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--faint); padding:15px 11px 7px; }
  .sidebar .nav{ display:flex; align-items:center; gap:12px; padding:10px 11px; border-radius:9px; color:var(--ink2);
    font-size:14.5px; font-weight:500; cursor:pointer; }
  .sidebar .nav svg{ width:18px; height:18px; color:var(--faint); flex:none; }
  .sidebar .nav:hover{ background:var(--raised); }
  .sidebar .nav.on{ background:var(--surface); color:var(--ink); font-weight:600; border:1px solid var(--line); box-shadow:var(--shadow); }
  .sidebar .nav.on svg{ color:var(--accent); }
  .sidebar .nav .ct{ margin-left:auto; font-size:11.5px; color:var(--muted); font-weight:600; background:var(--raised2); padding:1px 8px; border-radius:99px; }
  .sidebar .nav.on .ct{ background:var(--accent-soft); color:var(--accent); }
  .sidebar .side-foot{ margin-top:auto; display:flex; align-items:center; gap:10px; padding:11px; border-radius:11px; border:1px solid var(--line); background:var(--surface); }
  .sidebar .side-foot .ot b{ font-size:13px; font-weight:600; display:block; }
  .sidebar .side-foot .ot span{ font-size:11px; color:var(--muted); }

  .bottomnav{ display:none; }
  .appbar{ height:62px; padding:0 26px; }
  .appbar .brand{ display:none; }
  .appbar .search{ flex:1; max-width:440px; height:40px; border:1px solid var(--line-strong); border-radius:11px;
    background:var(--surface); display:flex; align-items:center; gap:10px; padding:0 14px; color:var(--faint); }
  .appbar .search input{ border:0; background:none; outline:none; font:inherit; font-size:13.5px; color:var(--ink); flex:1; }
  .page{ padding:30px 36px 48px; max-width:1180px; }
  .page.wide{ max-width:none; }
}
.appbar .search{ display:none; }
@media (min-width:1000px){ .appbar .search{ display:flex; } .appbar .m-search{ display:none; } }

/* ---- search trigger button (desktop) ---- */
.appbar .search{ align-items:center; gap:10px; cursor:text; border:1px solid var(--line-strong);
  background:var(--surface); color:var(--faint); text-align:left; }
.appbar .search .search-ph{ flex:1; font-size:13.5px; }
.appbar .search .kbd{ font-family:var(--mono); font-size:11px; font-weight:600; color:var(--muted);
  background:var(--raised2); border:1px solid var(--line); border-radius:6px; padding:2px 7px; }

/* ---- role switcher / foot ---- */
.sidebar .side-foot{ width:100%; cursor:pointer; text-align:left; font:inherit; position:relative; }
.sidebar .side-foot:hover{ background:var(--raised); }
.sidebar .side-foot .sf-switch{ margin-left:auto; color:var(--faint); flex:none; }
.role-av.info{ background:var(--info-bg); color:var(--info); }
.role-av.accent{ background:var(--accent-soft); color:var(--accent); }
.role-av.neutral{ background:var(--neutral-bg); color:var(--neutral); }
.role-av.warn{ background:var(--warn-bg); color:var(--warn); }
.role-opt{ display:flex; align-items:center; gap:11px; width:100%; padding:11px 10px; border-radius:10px;
  border:0; background:none; font:inherit; cursor:pointer; }
.role-opt:hover{ background:var(--raised); }
.role-opt.on{ background:var(--accent-tint); }
.role-opt .role-dot{ width:10px; height:10px; border-radius:50%; flex:none; }
.role-dot.info{ background:var(--info); } .role-dot.accent{ background:var(--accent); }
.role-dot.neutral{ background:var(--neutral); } .role-dot.warn{ background:var(--warn); }
.role-opt .ro-n{ display:block; font-size:14px; font-weight:600; color:var(--ink); }
.role-opt .ro-d{ display:block; font-size:11.5px; color:var(--muted); margin-top:1px; }

/* ---- role banner ---- */
.role-banner{ display:flex; align-items:center; gap:10px; padding:9px 16px; font-size:13px; color:var(--ink2);
  background:var(--accent-tint); border-bottom:1px solid var(--line); }
.role-banner.info{ background:var(--info-bg); } .role-banner.neutral{ background:var(--neutral-bg); } .role-banner.warn{ background:var(--warn-bg); }
.role-banner b{ font-weight:700; }
.role-banner > span:nth-child(2){ flex:1; }
.role-banner button{ font:inherit; font-size:12.5px; font-weight:600; color:var(--accent); background:none; border:0; cursor:pointer; white-space:nowrap; }
@media (min-width:1000px){ .role-banner{ padding:9px 26px; } }
@media (max-width:999px){ .role-banner span:nth-child(2){ font-size:12px; } }
