:root{--bg-0: #0a0b0e;--bg-1: #101216;--bg-2: #161922;--bg-3: #1c1f29;--bg-input: #0d0f13;--line: #1f232c;--line-soft: #181b22;--line-strong: #2a2f3a;--line-focus: #3a4150;--text-0: #ecedef;--text-1: #b6bac3;--text-2: #7e8490;--text-3: #555c69;--text-4: #3a4150;--accent: oklch(74% .13 75);--accent-soft: oklch(74% .13 75 / .14);--accent-line: oklch(74% .13 75 / .35);--accent-ink: oklch(28% .05 75);--ok: oklch(72% .14 152);--ok-soft: oklch(72% .14 152 / .14);--warn: oklch(76% .14 70);--warn-soft: oklch(76% .14 70 / .14);--danger: oklch(66% .2 25);--danger-soft: oklch(66% .2 25 / .14);--info: oklch(72% .1 240);--info-soft: oklch(72% .1 240 / .14);--muted: oklch(60% .02 250);--v-konoha: oklch(72% .14 142);--v-suna: oklch(76% .14 70);--v-ame: oklch(70% .1 250);--v-kiri: oklch(72% .08 200);--v-koumo: oklch(68% .13 320);--font-sans: "Geist", "Söhne", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Geist Mono", "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;--sidebar-w: 232px;--topbar-h: 48px;--radius: 6px;--radius-sm: 4px;--radius-lg: 10px}:root[data-theme=light]{--bg-0: #f6f3ec;--bg-1: #fbf9f4;--bg-2: #ffffff;--bg-3: #f1ede3;--bg-input: #ffffff;--line: #e3ddcf;--line-soft: #ecead9;--line-strong: #cfc7b3;--line-focus: #b2a890;--text-0: #1a1a1a;--text-1: #3d3d3d;--text-2: #6c6c6c;--text-3: #969085;--text-4: #bcb6a8}:root[data-theme=sepia]{--bg-0: #1c160d;--bg-1: #221b10;--bg-2: #281f12;--bg-3: #312614;--bg-input: #19140a;--line: #382a17;--line-soft: #2a2010;--line-strong: #4a3820;--line-focus: #5e4a2c;--text-0: #f1e6cd;--text-1: #cfbf9b;--text-2: #998a6a;--text-3: #6f6347;--text-4: #4d4530;--accent: oklch(78% .14 78)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg-0);color:var(--text-0);font:13px/1.5 var(--font-sans);font-feature-settings:"ss01","ss02","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,textarea,select{font:inherit;color:inherit}button{background:none;border:0;padding:0;cursor:pointer}a{color:inherit;text-decoration:none}hr{border:0;border-top:1px solid var(--line);margin:0}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:5px;border:2px solid var(--bg-0)}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"side top" "side main";height:100vh}.topbar{grid-area:top;display:flex;align-items:center;border-bottom:1px solid var(--line);padding:0 16px;gap:18px;background:var(--bg-0);position:relative;z-index:3}.sidebar{grid-area:side;border-right:1px solid var(--line);background:var(--bg-1);display:flex;flex-direction:column;overflow-y:auto}.main{grid-area:main;overflow-y:auto;background:var(--bg-0)}.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-1);padding:0 16px;height:var(--topbar-h);border-bottom:1px solid var(--line);border-right:1px solid var(--line);margin:0 -16px;background:var(--bg-1);width:var(--sidebar-w);position:absolute;left:calc(-1 * var(--sidebar-w));top:0}.brand-mark{width:18px;height:18px;border-radius:4px;background:var(--accent);display:grid;place-items:center;color:var(--accent-ink);font-weight:700;font-size:11px}.brand-name{color:var(--text-0);font-weight:600}.brand-sep{color:var(--text-3)}.brand-env{margin-left:auto;font-size:10px;color:var(--text-3);border:1px solid var(--line);padding:2px 6px;border-radius:3px}.crumbs{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11.5px;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em}.crumbs .sep{color:var(--text-4)}.crumbs .cur{color:var(--text-0)}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.search{flex:1;max-width:360px;background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius);padding:4px 10px 4px 28px;color:var(--text-1);height:28px;font-size:12px;position:relative;display:flex;align-items:center;gap:6px}.search input{flex:1;background:none;border:0;outline:none;padding:0;font-family:var(--font-mono);font-size:12px}.search .kbd{font-family:var(--font-mono);font-size:10px;color:var(--text-3);border:1px solid var(--line);padding:1px 4px;border-radius:3px}.side-section{padding:16px 12px 6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);display:flex;align-items:center;justify-content:space-between}.side-nav{padding:0 8px;display:flex;flex-direction:column;gap:1px}.nav-item{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:var(--radius-sm);color:var(--text-1);font-size:12.5px;position:relative;cursor:pointer}.nav-item:hover,.nav-item.active{background:var(--bg-2);color:var(--text-0)}.nav-item.active:before{content:"";position:absolute;left:-8px;top:6px;bottom:6px;width:2px;background:var(--accent);border-radius:2px}.nav-icon{width:14px;height:14px;color:var(--text-2);flex-shrink:0}.nav-item.active .nav-icon{color:var(--text-0)}.nav-badge{margin-left:auto;font-family:var(--font-mono);font-size:10px;background:var(--danger-soft);color:var(--danger);padding:1px 6px;border-radius:8px;line-height:1.4}.nav-badge.muted{background:var(--bg-3);color:var(--text-2)}.side-user{margin-top:auto;border-top:1px solid var(--line);padding:10px 12px;display:flex;align-items:center;gap:10px}.side-user .avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--accent),oklch(60% .16 30));display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;color:var(--accent-ink);font-weight:700}.side-user .meta{flex:1;min-width:0}.side-user .meta .name{font-size:12px;color:var(--text-0)}.side-user .meta .role{font-family:var(--font-mono);font-size:10px;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em}.side-user .status-dot{width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 2px var(--ok-soft)}.page{padding:18px 22px 32px;max-width:1600px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:18px}.page-title{font-size:20px;font-weight:600;letter-spacing:-.01em;margin:0 0 4px}.page-sub{color:var(--text-2);font-size:12.5px;display:flex;align-items:center;gap:10px}.page-sub .dot{width:4px;height:4px;border-radius:50%;background:var(--text-4)}.card{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.card.raised{background:var(--bg-2)}.card-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--line-soft);gap:12px}.card-title{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-2);display:flex;align-items:center;gap:8px}.card-title .count{background:var(--bg-3);color:var(--text-1);padding:1px 6px;border-radius:8px;font-size:9.5px}.card-body{padding:14px}.card-body.tight{padding:0}.btn{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--radius-sm);font-size:12px;color:var(--text-1);background:var(--bg-2);border:1px solid var(--line);cursor:pointer;transition:background .12s,border-color .12s;white-space:nowrap}.btn:hover{background:var(--bg-3);border-color:var(--line-strong);color:var(--text-0)}.btn.primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent);font-weight:600}.btn.primary:hover{filter:brightness(1.08)}.btn.ghost{background:transparent;border-color:transparent}.btn.ghost:hover{background:var(--bg-2)}.btn.danger{color:var(--danger);border-color:#f4514f4d;background:var(--danger-soft)}.btn.danger:hover{background:#f4514f38}.btn.ok{color:var(--ok);border-color:#56bd784d;background:var(--ok-soft)}.btn.ok:hover{background:#56bd7838}.btn.sm{padding:3px 7px;font-size:11px}.btn .ico{width:12px;height:12px}.badge{display:inline-flex;align-items:center;gap:4px;padding:1.5px 6px;border-radius:3px;font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;background:var(--bg-3);color:var(--text-1);border:1px solid var(--line);white-space:nowrap}.badge.ok{background:var(--ok-soft);color:var(--ok);border-color:#56bd7840}.badge.warn{background:var(--warn-soft);color:var(--warn);border-color:#e9a03e40}.badge.danger{background:var(--danger-soft);color:var(--danger);border-color:#f4514f40}.badge.info{background:var(--info-soft);color:var(--info);border-color:#67addd40}.badge.accent{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-line)}.badge.dim{background:transparent;color:var(--text-3);border-color:var(--line)}.dot-status{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}.dot-status.ok{background:var(--ok);box-shadow:0 0 0 2px var(--ok-soft)}.dot-status.warn{background:var(--warn);box-shadow:0 0 0 2px var(--warn-soft)}.dot-status.danger{background:var(--danger);box-shadow:0 0 0 2px var(--danger-soft)}.dot-status.muted{background:var(--text-3)}.tbl{width:100%;border-collapse:collapse}.tbl th{text-align:left;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-weight:500;padding:8px 12px;border-bottom:1px solid var(--line);background:var(--bg-1);position:sticky;top:0;white-space:nowrap}.tbl td{padding:8px 12px;font-size:12.5px;color:var(--text-1);border-bottom:1px solid var(--line-soft);vertical-align:middle}.tbl tr:hover td{background:var(--bg-2)}.tbl tr.clickable{cursor:pointer}.tbl td.mono{font-family:var(--font-mono);font-size:11.5px;color:var(--text-2)}.tbl td.right{text-align:right}.tbl td.num{font-family:var(--font-mono);text-align:right;color:var(--text-0)}.field{display:flex;flex-direction:column;gap:4px}.field label{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2)}.field input,.field select,.field textarea{background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);padding:6px 10px;color:var(--text-0);outline:none;font-size:12.5px}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--line-focus)}.field textarea{font-family:var(--font-sans);resize:vertical;min-height:64px}.sparkbar{display:flex;align-items:flex-end;gap:2px;height:22px}.sparkbar>span{flex:1;background:var(--text-3);border-radius:1px;min-height:1px;opacity:.65}.gauge{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center}.gauge-circle{width:96px;height:96px;position:relative}.gauge-num{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-family:var(--font-mono);font-size:26px;font-weight:600;color:var(--text-0)}.gauge-sub{font-size:10px;color:var(--text-2);margin-top:18px}.row{display:flex;align-items:center;gap:8px}.col{display:flex;flex-direction:column;gap:8px}.grid-12{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.span-3{grid-column:span 3}.span-4{grid-column:span 4}.span-5{grid-column:span 5}.span-6{grid-column:span 6}.span-7{grid-column:span 7}.span-8{grid-column:span 8}.span-9{grid-column:span 9}.span-12{grid-column:span 12}.mono{font-family:var(--font-mono)}.dim{color:var(--text-3)}.muted{color:var(--text-2)}.uppercase{text-transform:uppercase;letter-spacing:.06em}.small{font-size:11px}.tiny{font-size:10px}.right{text-align:right}.spacer{flex:1}.stack-2>*+*{margin-top:8px}.stat{padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-1);display:flex;flex-direction:column;gap:4px}.stat .label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-2)}.stat .val{font-family:var(--font-mono);font-size:22px;color:var(--text-0);font-weight:600;line-height:1.1;letter-spacing:-.01em}.stat .delta{font-family:var(--font-mono);font-size:10.5px;color:var(--text-2);display:flex;align-items:center;gap:6px}.stat .delta.up{color:var(--ok)}.stat .delta.down{color:var(--danger)}.village-pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-1)}.village-pill .glyph{width:12px;height:12px;border-radius:3px;display:inline-block;background:var(--text-3)}.bar-row{display:grid;grid-template-columns:90px 1fr 56px;align-items:center;gap:10px}.bar-row+.bar-row{margin-top:8px}.bar-row .lbl{font-family:var(--font-mono);font-size:11px;color:var(--text-1);text-transform:uppercase;letter-spacing:.06em}.bar-row .track{height:8px;background:var(--bg-3);border-radius:2px;overflow:hidden}.bar-row .fill{height:100%;background:var(--text-2);border-radius:2px;transition:width .4s}.bar-row .num{font-family:var(--font-mono);font-size:11px;color:var(--text-0);text-align:right}.pyramid{display:flex;flex-direction:column;gap:6px}.pyramid-row{display:grid;grid-template-columns:110px 1fr 50px;align-items:center;gap:12px;padding:6px 0;cursor:pointer;border-radius:3px}.pyramid-row:hover{background:var(--bg-2)}.pyramid-row .lbl{font-family:var(--font-mono);font-size:11px;color:var(--text-1);text-transform:uppercase;letter-spacing:.06em;padding-left:8px}.pyramid-row .bar{height:18px;background:var(--bg-3);border-radius:2px;position:relative;overflow:hidden}.pyramid-row .fill{position:absolute;left:0;top:0;bottom:0}.pyramid-row .count{font-family:var(--font-mono);font-size:11.5px;color:var(--text-0);text-align:right;padding-right:8px}.heat{display:grid;grid-template-columns:repeat(24,1fr);gap:2px}.heat .cell{aspect-ratio:1;background:var(--bg-3);border-radius:1px}.modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-1);border:1px solid var(--line-strong);border-radius:var(--radius-lg);width:min(720px,92vw);max-height:88vh;display:flex;flex-direction:column;box-shadow:0 24px 80px #00000080}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}.modal-title{font-size:14px;font-weight:600;color:var(--text-0)}.modal-body{padding:16px;overflow-y:auto}.modal-foot{padding:12px 16px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}.banner{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius);border:1px solid var(--line);background:var(--bg-1)}.banner.danger{border-color:#f4514f59;background:var(--danger-soft)}.banner.warn{border-color:#e9a03e59;background:var(--warn-soft)}.banner.info{border-color:#67addd59;background:var(--info-soft)}.banner .icon{flex-shrink:0}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:14px}.tab{padding:8px 12px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-2);border-bottom:1.5px solid transparent;cursor:pointer;margin-bottom:-1px}.tab:hover{color:var(--text-0)}.tab.active{color:var(--text-0);border-bottom-color:var(--accent)}.toolbar{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--line-soft);background:var(--bg-1)}.toolbar input[type=text]{background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);padding:4px 8px;color:var(--text-0);outline:none;font-size:12px;height:26px}.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;font-family:var(--font-mono);font-size:11px;background:var(--bg-2);border:1px solid var(--line);border-radius:999px;color:var(--text-1);cursor:pointer}.chip:hover{border-color:var(--line-strong);color:var(--text-0)}.chip.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-line)}.feed{display:flex;flex-direction:column}.feed-item{display:grid;grid-template-columns:18px 1fr auto;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--line-soft);font-size:12.5px;color:var(--text-1)}.feed-item:last-child{border-bottom:0}.feed-item .ico-circle{width:18px;height:18px;border-radius:50%;background:var(--bg-3);color:var(--text-2);display:grid;place-items:center}.feed-item .when{font-family:var(--font-mono);font-size:10.5px;color:var(--text-3)}.feed-item a{color:var(--text-0)}.feed-item a:hover{color:var(--accent)}code,.code{font-family:var(--font-mono);font-size:11px;background:var(--bg-3);color:var(--text-1);padding:1px 5px;border-radius:3px}.village-card.locked{opacity:.55;filter:saturate(.4)}.village-card.locked:after{content:"À VENIR";position:absolute;top:10px;right:10px;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.12em;color:var(--text-2);border:1px dashed var(--line-strong);padding:2px 6px;border-radius:3px}.risk{display:flex;align-items:center;gap:10px}.risk-bar{flex:1;height:6px;background:var(--bg-3);border-radius:3px;overflow:hidden}.risk-bar>span{display:block;height:100%;transition:width .25s}.risk-num{font-family:var(--font-mono);font-size:13px;font-weight:600}.risk-num.ok{color:var(--ok)}.risk-num.warn{color:var(--warn)}.risk-num.danger{color:var(--danger)}
