/* ============================================================
   Narabuzz Backoffice — Design Tokens & Base
   HIGHFIVE株式会社 / グッズ制作・物販・倉庫・EC
   ============================================================ */
:root{
  /* Brand orange */
  --brand:        #F5901E;
  --brand-deep:   #E1760A;
  --brand-press:  #C76307;
  --brand-soft:   #FCB65A;
  --brand-wash:   #FEF4E7;
  --brand-wash-2: #FBE7CC;

  /* Warm neutrals */
  --bg:        #F5F3EF;
  --surface:   #FFFFFF;
  --surface-2: #FAF8F4;
  --surface-3: #F1EEE8;
  --border:    #E8E3DB;
  --border-2:  #D9D3C8;
  --ink:       #211E19;
  --ink-2:     #5B564C;
  --ink-3:     #908A7D;
  --ink-4:     #B4AE9F;

  /* Sidebar (dark warm) */
  --side-bg:     #1F1C17;
  --side-bg-2:   #2A261F;
  --side-ink:    #C9C2B4;
  --side-ink-2:  #8C8576;
  --side-border: #322D25;

  /* Financial semantics */
  --revenue:      #1C875A;   /* 自社確定売上 = ours */
  --revenue-soft: #E6F3EB;
  --revenue-ink:  #15724B;
  --deposit:      #5360A6;   /* 預かり金 = held / not ours */
  --deposit-soft: #ECEEF8;
  --deposit-ink:  #41509A;
  --total-ink:    #211E19;   /* 総入金 = neutral */

  /* Status */
  --st-pend-bg:#FBEED6; --st-pend-ink:#996A12;   /* 精算待ち / 未締め */
  --st-done-bg:#E6F3EB; --st-done-ink:#1C7A4F;   /* 精算済 / 入金済 */
  --st-prog-bg:#E7EDF9; --st-prog-ink:#3A5CA3;   /* 進行中 / 送付済 */
  --st-draft-bg:#EFEBE4; --st-draft-ink:#6E695E; /* 下書き */
  --st-warn-bg:#FBE3DC; --st-warn-ink:#B0492C;   /* 超過 / 警告 */

  --r-xs: 5px; --r-sm: 8px; --r: 11px; --r-lg: 14px; --r-xl: 20px; --r-pill: 999px;

  --sh-xs: 0 1px 2px rgba(34,28,18,.05);
  --sh-sm: 0 1px 3px rgba(34,28,18,.06), 0 1px 2px rgba(34,28,18,.04);
  --sh:    0 4px 14px rgba(34,28,18,.07), 0 1px 3px rgba(34,28,18,.05);
  --sh-lg: 0 18px 48px rgba(34,28,18,.16), 0 4px 12px rgba(34,28,18,.08);

  --font: "Zen Kaku Gothic New", -apple-system, "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; height:100%; overflow:hidden; overscroll-behavior:none; }
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"palt" 1;
}
h1,h2,h3,h4{ line-height:1.32; }
::selection{ background:var(--brand-wash-2); }
.num{ font-variant-numeric:tabular-nums; letter-spacing:-.01em; }
.mono{ font-family:var(--mono); font-variant-numeric:tabular-nums; }

/* scrollbars */
::-webkit-scrollbar{ width:10px; height:10px; }
::-webkit-scrollbar-thumb{ background:#D8D2C7; border-radius:99px; border:2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover{ background:#C5BEB0; }

/* ============================================================ APP SHELL */
#root{ height:100vh; height:100dvh; }
.app{ display:grid; grid-template-columns:248px 1fr; height:100vh; height:100dvh; overflow:hidden; }

/* ---- Sidebar ---- */
.side{ background:var(--side-bg); color:var(--side-ink); display:flex; flex-direction:column; border-right:1px solid var(--side-border); }
.side-head{ display:flex; align-items:center; gap:11px; padding:18px 18px 16px; }
.side-mark{ width:40px; height:40px; flex:none; border-radius:11px; background:#FBF4E8; display:grid; place-items:center; overflow:hidden; box-shadow:inset 0 0 0 1px rgba(0,0,0,.05); }
.side-mark img{ width:36px; height:36px; display:block; object-fit:contain; }
.side-brand{ display:flex; flex-direction:column; line-height:1.1; min-width:0; }
.side-brand b{ font-size:13.5px; font-weight:700; color:#F4EFE6; letter-spacing:.06em; white-space:nowrap; }
.side-brand span{ font-size:10.5px; color:var(--side-ink-2); margin-top:4px; letter-spacing:.02em; white-space:nowrap; }
/* typographic wordmark */
.wordmark{ display:flex; flex-direction:column; gap:4px; min-width:0; line-height:1; }
.wordmark b{ font-family:var(--mono); font-size:18px; font-weight:700; color:#F4EFE6; letter-spacing:.2em; line-height:1; }
.wordmark span{ font-size:8.5px; font-weight:700; letter-spacing:.38em; color:var(--brand); text-transform:uppercase; line-height:1; }
.side-nav{ flex:1; overflow-y:auto; padding:6px 10px; }
.side-nav::-webkit-scrollbar-thumb{ background:#3a352c; border-color:var(--side-bg); }
.nav-sec{ font-size:10px; font-weight:700; letter-spacing:.12em; color:var(--side-ink-2); padding:16px 10px 7px; text-transform:uppercase; }
.nav-item{ display:flex; align-items:center; gap:11px; padding:9px 11px; border-radius:9px; color:var(--side-ink); font-size:13.5px; font-weight:500; cursor:pointer; position:relative; transition:background .12s, color .12s; user-select:none; white-space:nowrap; }
.nav-item:hover{ background:rgba(255,255,255,.045); color:#EDE7DB; }
.nav-item.active{ background:var(--brand); color:#fff; box-shadow:0 2px 10px rgba(245,144,30,.32); }
.nav-item.active .nav-ic{ opacity:1; }
.nav-ic{ width:18px; height:18px; flex:none; opacity:.78; }
.nav-badge{ margin-left:auto; font-size:10.5px; font-weight:700; padding:1px 7px; border-radius:99px; background:rgba(255,255,255,.12); color:#EDE7DB; }
.nav-item.active .nav-badge{ background:rgba(255,255,255,.25); color:#fff; }
.nav-badge.alert{ background:var(--brand); color:#fff; }
.nav-item.active .nav-badge.alert{ background:rgba(255,255,255,.28); }
.side-foot{ padding:12px; border-top:1px solid var(--side-border); }
.side-user{ display:flex; align-items:center; gap:10px; padding:8px; border-radius:10px; cursor:pointer; transition:background .12s; }
.side-user:hover{ background:rgba(255,255,255,.045); }
.side-ava{ width:32px; height:32px; border-radius:50%; flex:none; display:grid; place-items:center; font-size:12px; font-weight:700; color:#fff; }
.side-user-meta{ line-height:1.25; min-width:0; }
.side-user-meta b{ font-size:12.5px; color:#EDE7DB; font-weight:600; display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.side-user-meta span{ font-size:10.5px; color:var(--side-ink-2); }

/* ---- Main ---- */
.main{ display:flex; flex-direction:column; min-width:0; overflow:hidden; }
.topbar{ height:60px; flex:none; background:rgba(255,255,255,.86); backdrop-filter:blur(8px); border-bottom:1px solid var(--border); display:flex; align-items:center; gap:16px; padding:0 26px; z-index:20; }
.crumb{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink-3); }
.crumb b{ color:var(--ink); font-weight:700; font-size:15.5px; white-space:nowrap; }
.crumb svg{ width:14px; height:14px; opacity:.5; }
.topbar-spacer{ flex:1; }
.searchbox{ display:flex; align-items:center; gap:8px; height:36px; padding:0 12px; background:var(--surface-3); border:1px solid transparent; border-radius:9px; width:228px; color:var(--ink-3); font-size:12.5px; cursor:text; transition:.14s; }
.searchbox:hover{ background:#ECE8E1; }
.searchbox kbd{ margin-left:auto; font-family:var(--mono); font-size:10px; background:var(--surface); border:1px solid var(--border-2); border-radius:4px; padding:1px 5px; color:var(--ink-3); }
.icon-btn{ width:36px; height:36px; border-radius:9px; border:1px solid var(--border); background:var(--surface); display:grid; place-items:center; cursor:pointer; color:var(--ink-2); transition:.12s; position:relative; }
.icon-btn:hover{ background:var(--surface-2); border-color:var(--border-2); color:var(--ink); }
.icon-btn .dot{ position:absolute; top:7px; right:8px; width:7px; height:7px; border-radius:50%; background:var(--brand); border:1.5px solid var(--surface); }

/* role switcher */
.role-switch{ display:flex; align-items:center; gap:7px; height:36px; padding:0 12px 0 10px; border-radius:9px; border:1px solid var(--border); background:var(--surface); cursor:pointer; transition:.12s; }
.role-switch:hover{ background:var(--surface-2); border-color:var(--border-2); }
.role-dot{ width:8px; height:8px; border-radius:50%; flex:none; }
.role-switch b{ font-size:12.5px; font-weight:600; color:var(--ink); }
.role-switch svg{ width:13px; height:13px; color:var(--ink-3); }

.scroll{ flex:1; overflow-y:auto; overscroll-behavior:contain; -webkit-overflow-scrolling:touch; }
.page{ max-width:1240px; margin:0 auto; padding:26px 30px 80px; }
.page-wide{ max-width:1360px; }

/* ============================================================ PRIMITIVES */
.row{ display:flex; align-items:center; }
.col{ display:flex; flex-direction:column; }
.gap6{ gap:6px;} .gap8{ gap:8px;} .gap10{ gap:10px;} .gap12{ gap:12px;} .gap16{ gap:16px;} .gap20{ gap:20px;}
.spacer{ flex:1; }
.mt4{margin-top:4px;} .mt8{margin-top:8px;} .mt12{margin-top:12px;} .mt16{margin-top:16px;} .mt20{margin-top:20px;} .mt24{margin-top:24px;}
.muted{ color:var(--ink-3); }
.tnum{ font-variant-numeric:tabular-nums; }

.card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--sh-sm); }
.card-pad{ padding:20px 22px; }
.card-head{ display:flex; align-items:center; gap:10px; padding:16px 20px; border-bottom:1px solid var(--border); }
.card-head h3{ margin:0; font-size:14px; font-weight:700; color:var(--ink); }
.card-head .sub{ font-size:11.5px; color:var(--ink-3); }

.page-title{ font-size:22px; font-weight:700; letter-spacing:.01em; margin:0; line-height:1.25; }
.page-sub{ font-size:13px; color:var(--ink-3); margin:5px 0 0; }
.sec-title{ font-size:12px; font-weight:700; letter-spacing:.06em; color:var(--ink-3); text-transform:uppercase; }

/* buttons */
.btn{ display:inline-flex; align-items:center; gap:7px; height:38px; padding:0 16px; border-radius:9px; font-family:inherit; font-size:13px; font-weight:600; cursor:pointer; border:1px solid var(--border); background:var(--surface); color:var(--ink); transition:.13s; white-space:nowrap; }
.btn:hover{ background:var(--surface-2); border-color:var(--border-2); }
.btn svg{ width:16px; height:16px; }
.btn.primary{ background:var(--brand); border-color:var(--brand); color:#fff; box-shadow:0 2px 8px rgba(245,144,30,.28); }
.btn.primary:hover{ background:var(--brand-deep); border-color:var(--brand-deep); }
.btn.ghost{ background:transparent; border-color:transparent; color:var(--ink-2); }
.btn.ghost:hover{ background:var(--surface-3); color:var(--ink); }
.btn.sm{ height:32px; padding:0 12px; font-size:12px; border-radius:8px; }
.btn.lg{ height:44px; padding:0 22px; font-size:14px; }
.btn:disabled{ opacity:.45; cursor:not-allowed; }

/* badge */
.badge{ display:inline-flex; align-items:center; gap:5px; height:23px; padding:0 9px; border-radius:var(--r-pill); font-size:11.5px; font-weight:600; letter-spacing:.01em; white-space:nowrap; }
.badge .bdot{ width:6px; height:6px; border-radius:50%; }
.badge.pend{ background:var(--st-pend-bg); color:var(--st-pend-ink); }
.badge.done{ background:var(--st-done-bg); color:var(--st-done-ink); }
.badge.prog{ background:var(--st-prog-bg); color:var(--st-prog-ink); }
.badge.draft{ background:var(--st-draft-bg); color:var(--st-draft-ink); }
.badge.warn{ background:var(--st-warn-bg); color:var(--st-warn-ink); }
.badge.brand{ background:var(--brand-wash); color:var(--brand-press); }
.badge.dep{ background:var(--deposit-soft); color:var(--deposit-ink); }
.badge.rev{ background:var(--revenue-soft); color:var(--revenue-ink); }

/* chips for biz type */
.chip{ display:inline-flex; align-items:center; gap:6px; height:24px; padding:0 10px; border-radius:7px; font-size:11.5px; font-weight:600; background:var(--surface-3); color:var(--ink-2); border:1px solid transparent; }
.chip .cdot{ width:7px; height:7px; border-radius:2px; }

/* tables */
table.tbl{ width:100%; border-collapse:collapse; font-size:13px; }
.tbl thead th{ text-align:left; font-size:11px; font-weight:700; letter-spacing:.04em; color:var(--ink-3); padding:11px 14px; border-bottom:1px solid var(--border); white-space:nowrap; position:sticky; top:0; background:var(--surface); z-index:1; }
.tbl thead th.r, .tbl td.r{ text-align:right; }
.tbl tbody td{ padding:13px 14px; border-bottom:1px solid var(--border); color:var(--ink); vertical-align:middle; }
.tbl tbody tr{ transition:background .1s; }
.tbl tbody tr.clickable{ cursor:pointer; }
.tbl tbody tr.clickable:hover{ background:var(--surface-2); }
.tbl tbody tr:last-child td{ border-bottom:none; }
.tbl td .sub{ font-size:11px; color:var(--ink-3); margin-top:2px; }

/* KPI */
.kpi{ background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:18px 20px; position:relative; overflow:hidden; box-shadow:var(--sh-sm); }
.kpi .klabel{ font-size:12px; font-weight:600; color:var(--ink-2); display:flex; align-items:center; gap:7px; }
.kpi .kval{ font-size:30px; font-weight:700; margin-top:11px; letter-spacing:-.02em; line-height:1; }
.kpi .ksub{ font-size:11.5px; color:var(--ink-3); margin-top:9px; display:flex; align-items:center; gap:6px; }
.kpi .kbar-l{ position:absolute; left:0; top:0; bottom:0; width:4px; }
.kpi .kyen{ font-size:17px; font-weight:700; opacity:.6; margin-right:1px; }

/* progress */
.prog{ height:8px; border-radius:99px; background:var(--surface-3); overflow:hidden; }
.prog>i{ display:block; height:100%; border-radius:99px; }

/* avatar */
.ava{ border-radius:50%; display:grid; place-items:center; font-weight:700; color:#fff; flex:none; }

/* divider */
.hr{ height:1px; background:var(--border); border:none; margin:0; }

/* segmented */
.seg{ display:inline-flex; background:var(--surface-3); border-radius:9px; padding:3px; gap:2px; }
.seg button{ border:none; background:transparent; font-family:inherit; font-size:12.5px; font-weight:600; color:var(--ink-3); padding:6px 13px; border-radius:7px; cursor:pointer; transition:.12s; }
.seg button:hover{ color:var(--ink); }
.seg button.on{ background:var(--surface); color:var(--ink); box-shadow:var(--sh-xs); }

/* tabs */
.tabs{ display:flex; gap:2px; border-bottom:1px solid var(--border); }
.tab{ padding:11px 15px; font-size:13px; font-weight:600; color:var(--ink-3); cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-1px; transition:.12s; }
.tab:hover{ color:var(--ink); }
.tab.on{ color:var(--brand-press); border-bottom-color:var(--brand); }

/* mini stat */
.minis{ display:flex; flex-direction:column; gap:4px; }
.minis .ml{ font-size:11.5px; color:var(--ink-3); font-weight:500; }
.minis .mv{ font-size:18px; font-weight:700; letter-spacing:-.01em; }

/* modal */
.scrim{ position:fixed; inset:0; background:rgba(28,23,15,.42); backdrop-filter:blur(2px); display:grid; place-items:center; z-index:100; padding:24px; }
@keyframes fade{ from{opacity:0;} to{opacity:1;} }
.modal{ background:var(--surface); border-radius:var(--r-xl); box-shadow:var(--sh-lg); width:100%; max-width:560px; max-height:90vh; overflow:hidden; display:flex; flex-direction:column; animation:pop .18s cubic-bezier(.2,.9,.3,1.2); }
@keyframes pop{ from{ transform:translateY(12px) scale(.98);} to{ transform:none;} }
.modal-head{ display:flex; align-items:flex-start; gap:12px; padding:20px 22px; border-bottom:1px solid var(--border); }
.modal-head h2{ margin:0; font-size:17px; font-weight:700; line-height:1.35; }
.modal-head p{ margin:4px 0 0; font-size:12.5px; color:var(--ink-3); }
.modal-body{ padding:22px; overflow-y:auto; }
.modal-foot{ display:flex; align-items:center; gap:10px; padding:16px 22px; border-top:1px solid var(--border); background:var(--surface-2); }
.x-btn{ margin-left:auto; width:32px; height:32px; border-radius:8px; border:none; background:var(--surface-3); cursor:pointer; display:grid; place-items:center; color:var(--ink-2); transition:.12s; flex:none; }
.x-btn:hover{ background:var(--border); }

/* settlement ledger rows */
.ledger{ display:flex; flex-direction:column; gap:1px; }
.ldg-row{ display:flex; align-items:center; justify-content:space-between; padding:13px 16px; background:var(--surface-2); font-size:13px; }
.ldg-row:first-child{ border-radius:10px 10px 0 0; }
.ldg-row.total{ background:var(--ink); color:#fff; border-radius:0 0 10px 10px; font-weight:700; }
.ldg-row.sub{ background:transparent; padding:9px 16px; color:var(--ink-2); font-size:12.5px; }
.ldg-row .lv{ font-weight:700; font-variant-numeric:tabular-nums; }

/* toast */
.toast{ position:fixed; bottom:24px; left:50%; transform:translateX(-50%); background:var(--ink); color:#fff; padding:12px 18px; border-radius:11px; font-size:13px; font-weight:600; box-shadow:var(--sh-lg); z-index:200; display:flex; align-items:center; gap:10px; animation:toastin .25s cubic-bezier(.2,.9,.3,1.2); }
@keyframes toastin{ from{ transform:translate(-50%,14px);} to{ transform:translate(-50%,0);} }
.toast svg{ width:18px; height:18px; color:var(--brand-soft); }

/* empty state mascot */
.empty{ display:flex; flex-direction:column; align-items:center; gap:14px; padding:48px 20px; text-align:center; color:var(--ink-3); }
.empty svg{ width:120px; height:120px; opacity:.92; }

/* relationship bar (deposit visualization) */
.relbar{ display:flex; height:46px; border-radius:11px; overflow:hidden; border:1px solid var(--border); }
.relbar .seg-b{ display:flex; align-items:center; justify-content:center; color:#fff; font-size:12.5px; font-weight:700; position:relative; transition:flex .5s cubic-bezier(.4,0,.2,1); min-width:2px; }
.relseg-label{ display:flex; align-items:center; gap:8px; font-size:12px; }
.relseg-label .sq{ width:11px; height:11px; border-radius:3px; flex:none; }

/* flow stepper */
.flow{ display:flex; align-items:stretch; gap:0; }
.flow-step{ flex:1; display:flex; flex-direction:column; gap:8px; padding:14px 14px; position:relative; }
.flow-step:not(:last-child)::after{ content:""; position:absolute; right:-1px; top:22px; width:2px; bottom:14px; }
.flow-num{ width:26px; height:26px; border-radius:50%; display:grid; place-items:center; font-size:12px; font-weight:700; flex:none; }

label.fld{ display:flex; flex-direction:column; gap:6px; font-size:12px; font-weight:600; color:var(--ink-2); }
.fld input, .fld select, .input{ height:38px; padding:0 12px; border:1px solid var(--border-2); border-radius:9px; font-family:inherit; font-size:13px; color:var(--ink); background:var(--surface); transition:.12s; width:100%; }
.fld input:focus, .input:focus{ outline:none; border-color:var(--brand); box-shadow:0 0 0 3px var(--brand-wash); }

.bizdot{ width:9px;height:9px;border-radius:3px;flex:none; }

/* ============================================================ LAYOUT GRID UTILITIES */
.grid{ display:grid; }
.grid.cols-2{ grid-template-columns:1fr 1fr; }
.grid.cols-3{ grid-template-columns:repeat(3,1fr); }
.grid.cols-4{ grid-template-columns:repeat(4,1fr); }
.grid.ratio-main{ grid-template-columns:1.6fr 1fr; }
.grid.ratio-14{ grid-template-columns:1.4fr 1fr; }
.grid.ratio-15{ grid-template-columns:1.5fr 1fr; }

/* hamburger / drawer scaffolding — hidden on desktop */
.only-sp{ display:none; }
.nav-overlay{ display:none; }

/* ============================================================ RESPONSIVE / SP */
/* tablet: 4-up KPI rows relax to 2-up */
@media (max-width:1024px){
  .grid.cols-4{ grid-template-columns:1fr 1fr; }
}

/* phone: drawer sidebar + single-column stacking */
@media (max-width:760px){
  /* shell → single column, sidebar becomes a slide-in drawer */
  .app{ grid-template-columns:1fr; }
  .side{ position:fixed; top:0; left:0; bottom:0; width:264px; z-index:60;
         transform:translateX(-100%); transition:transform .22s ease; box-shadow:var(--sh-lg); }
  .side.open{ transform:translateX(0); }
  .nav-overlay{ display:block; position:fixed; inset:0; background:rgba(20,16,10,.46); z-index:55; }
  .only-sp{ display:inline-flex; align-items:center; justify-content:center; }

  /* every multi-column grid stacks */
  .grid.cols-2,.grid.cols-3,.grid.cols-4,
  .grid.ratio-main,.grid.ratio-14,.grid.ratio-15{ grid-template-columns:1fr; }

  /* card list rows: let nowrap children (name/badge/amount/button) shrink & wrap
     instead of forcing horizontal overflow (broken flex min-width chain on SP) */
  .scroll .card .row{ min-width:0; flex-wrap:wrap; }
  .scroll .card .row b{ min-width:0; }

  /* topbar compaction */
  .topbar{ height:54px; gap:8px; padding:0 12px; }
  .crumb b{ font-size:14px; }
  .searchbox{ display:none; }
  .role-switch{ padding:0 9px; }
  .role-switch b{ display:none; }

  /* page padding */
  .page{ padding:18px 14px 64px; }
  .page-title{ font-size:19px; word-break:keep-all; }
  /* page header / toolbar rows: keep title intact, wrap controls below it */
  .page > .row{ flex-wrap:wrap; gap:12px; }
  /* segmented control: natural-width buttons, scroll if too many (don't squish labels) */
  .seg{ max-width:100%; overflow-x:auto; }
  .seg button{ flex:none; white-space:nowrap; }

  /* tables: scroll horizontally inside their card instead of squishing columns.
     !important overrides inline style={{overflow:"hidden"}} on some table cards. */
  .card:has(table.tbl){ overflow-x:auto !important; -webkit-overflow-scrolling:touch; }
  table.tbl{ min-width:640px; }
  .tbl th, .tbl td{ white-space:nowrap; }

  /* roomier modals on small screens */
  .scrim{ padding:12px; }
}
