:root{--ink: #102a43;--ink-2: #243b54;--ink-3: #486581;--muted: #6b7e8d;--faint: #9bacb9;--paper: #f5f8f9;--card: #ffffff;--line: #e3eaee;--line-2: #d2dde3;--teal: #0e9173;--teal-deep: #0a6b56;--teal-soft: #e2f4ee;--violet: #6457d6;--violet-deep: #4a3fae;--violet-soft: #edebfb;--gold: #e0a32e;--gold-deep: #b9821c;--gold-soft: #faf0d9;--clay: #d85a30;--clay-deep: #a8431f;--clay-soft: #fbeae3;--amber: #c07a12;--amber-soft: #faf0dc;--red: #c24141;--red-soft: #fbe9e9;--blue: #2a72b8;--blue-soft: #e7f0f9;--font-ui: "Inter", system-ui, -apple-system, sans-serif;--font-display: "Sora", "Inter", sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, monospace;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--shadow: 0 1px 2px rgba(14, 27, 37, .05), 0 4px 16px rgba(14, 27, 37, .05);--sidebar-w: 232px}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{font-family:var(--font-ui);background:var(--paper);color:var(--ink);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:var(--font-display);font-weight:600;margin:0;letter-spacing:-.01em}h1{font-size:21px}h2{font-size:16px}h3{font-size:14px}p{margin:0}a{color:var(--teal-deep);text-decoration:none}button{font-family:var(--font-ui);cursor:pointer}:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:4px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important}}.mono{font-family:var(--font-mono);font-size:12.5px}.muted{color:var(--muted)}.small{font-size:12px}.num{font-family:var(--font-display);font-variant-numeric:tabular-nums}.shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--ink);color:#cfdbe4;display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;z-index:40;padding:18px 12px;gap:4px}.brand{display:flex;align-items:center;gap:10px;padding:4px 10px 16px}.brand-mark{width:32px;height:32px;border-radius:9px;background:var(--ink);display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:15px}.brand-name{font-family:var(--font-display);font-weight:600;font-size:15px;color:#fff}.brand-sub{font-size:10.5px;color:#7d93a3;letter-spacing:.04em}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;color:#aebfcb;font-size:13.5px;font-weight:500;transition:background .15s,color .15s}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:#ffffff1a;color:#fff;box-shadow:inset 3px 0 0 var(--gold)}.nav-item .ico{width:19px;height:19px;flex:0 0 19px}.nav-spacer{flex:1}.nav-foot{padding:10px 12px;font-size:11px;color:#66798a;border-top:1px solid rgba(255,255,255,.08)}.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;gap:14px;padding:14px 26px;background:#f5f8f9e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:30;border-bottom:1px solid var(--line)}.topbar h1{flex:1}.env-pill{font-size:11px;font-weight:600;letter-spacing:.05em;padding:4px 10px;border-radius:999px;background:var(--gold-soft);color:var(--gold-deep)}.user-chip{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500}.avatar{width:30px;height:30px;border-radius:50%;background:var(--gold-soft);color:var(--gold-deep);display:grid;place-items:center;font-size:12px;font-weight:600}.content{padding:22px 26px 60px;display:flex;flex-direction:column;gap:16px;max-width:1240px;width:100%;margin:0 auto}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow)}.card-pad{padding:18px 20px}.card-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:14px;flex-wrap:wrap}.grid{display:grid;gap:14px}.grid-kpi{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.grid-2{grid-template-columns:repeat(auto-fit,minmax(330px,1fr))}.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;box-shadow:var(--shadow)}.kpi-label{font-size:12px;color:var(--muted);font-weight:500}.kpi-value{font-family:var(--font-display);font-size:26px;font-weight:600;letter-spacing:-.02em;margin-top:2px}.kpi-note{font-size:11.5px;margin-top:2px}.pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:500;padding:3px 9px;border-radius:999px;white-space:nowrap}.pill.teal{background:var(--teal-soft);color:var(--teal-deep)}.pill.violet{background:var(--violet-soft);color:var(--violet-deep)}.pill.clay{background:var(--clay-soft);color:var(--clay-deep)}.pill.amber{background:var(--amber-soft);color:var(--amber)}.pill.red{background:var(--red-soft);color:var(--red)}.pill.blue{background:var(--blue-soft);color:var(--blue)}.pill.gray{background:#eef2f4;color:var(--ink-3)}.pill.gold{background:var(--gold-soft);color:var(--gold-deep)}.ai-dot{width:7px;height:7px;border-radius:50%;background:var(--violet);animation:aipulse 2.2s ease-in-out infinite}@keyframes aipulse{0%,to{box-shadow:0 0 #6457d666}50%{box-shadow:0 0 0 6px #6457d600}}.btn{border:1px solid var(--line-2);background:var(--card);color:var(--ink);border-radius:9px;padding:8px 15px;font-size:13px;font-weight:500;transition:all .15s}.btn:hover{border-color:var(--faint);background:#fbfdfe}.btn:active{transform:scale(.98)}.btn.primary{background:var(--gold);border-color:var(--gold);color:var(--ink)}.btn.primary:hover{background:var(--gold-deep);border-color:var(--gold-deep);color:#fff}.btn.lg{padding:11px 20px;font-size:14px;border-radius:11px}.input,select.input{border:1px solid var(--line-2);border-radius:9px;padding:8px 12px;font-size:13px;font-family:var(--font-ui);background:var(--card);color:var(--ink);transition:border-color .15s}.input:focus{border-color:var(--gold);outline:none}.seg{display:inline-flex;background:#eaeff2;border-radius:10px;padding:3px;gap:2px;flex-wrap:wrap}.seg button{border:0;background:transparent;padding:6px 13px;border-radius:8px;font-size:12.5px;font-weight:500;color:var(--ink-3)}.seg button.on{background:var(--card);color:var(--ink);box-shadow:0 1px 3px #0e1b251f}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table.data{width:100%;border-collapse:collapse;font-size:13px;min-width:720px}table.data th{text-align:left;padding:10px 14px;font-size:11.5px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line);white-space:nowrap}table.data td{padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:top}table.data tbody tr{transition:background .12s;cursor:pointer}table.data tbody tr:hover{background:#f6fafb}table.data tr:last-child td{border-bottom:0}.t-right{text-align:right!important}.rail{display:flex;align-items:stretch;gap:0;overflow-x:auto;padding:6px 2px 14px}.rail-step{flex:1;min-width:150px;position:relative}.rail-node{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px;height:100%;display:flex;flex-direction:column;gap:5px;transition:border-color .15s,transform .15s;cursor:pointer}.rail-node:hover{border-color:var(--faint);transform:translateY(-1px)}.rail-node.sel{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}.rail-node.ai.sel{border-color:var(--violet);box-shadow:0 0 0 1px var(--violet)}.rail-day{font-size:10.5px;font-weight:600;letter-spacing:.06em;color:var(--faint);text-transform:uppercase}.rail-title{font-size:13px;font-weight:600}.rail-meta{font-size:11.5px;color:var(--muted)}.rail-close{font-family:var(--font-display);font-size:17px;font-weight:600}.rail-arrow{display:flex;align-items:center;padding:0 6px;color:var(--line-2);flex:0 0 auto}.rail-flow{height:5px;border-radius:3px;background:var(--line);position:relative;overflow:hidden;margin-top:7px}.rail-flow>i{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:3px;display:block}.hbar{display:flex;height:13px;border-radius:7px;overflow:hidden;background:var(--line)}.hbar>span{display:block;height:100%}.bar-row{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.bar-row .lbl{display:flex;justify-content:space-between;font-size:12.5px}.bar-track{height:11px;border-radius:6px;background:#edf1f4;overflow:hidden}.bar-track>span{display:block;height:100%;border-radius:6px}.drawer-veil{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e1b2566;z-index:60;animation:fade .18s ease}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(440px,100%);background:var(--card);z-index:61;box-shadow:-8px 0 32px #0e1b252e;padding:22px;overflow-y:auto;animation:slidein .22s cubic-bezier(.2,.8,.3,1)}@keyframes fade{0%{opacity:0}}@keyframes slidein{0%{transform:translate(40px);opacity:0}}.login-wrap{min-height:100vh;display:grid;place-items:center;background:var(--ink);padding:20px}.login-card{width:min(400px,100%);background:var(--card);border-radius:20px;padding:34px 32px;box-shadow:0 24px 64px #00000059}.login-grid-bg{position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);background-size:26px 26px;pointer-events:none}.portal{max-width:430px;margin:0 auto;min-height:100vh;background:var(--card);padding:20px 18px 40px}.portal-item{display:flex;align-items:center;gap:12px;border:1px solid var(--line-2);border-radius:var(--r-md);padding:13px 14px;margin-bottom:10px;cursor:pointer;transition:all .15s}.portal-item.on{border-color:var(--gold);background:var(--gold-soft)}.check{width:22px;height:22px;border-radius:7px;border:2px solid var(--line-2);display:grid;place-items:center;color:transparent;flex:0 0 22px;transition:all .15s}.portal-item.on .check{background:var(--gold);border-color:var(--gold);color:var(--ink)}.cta{width:100%;padding:14px;border-radius:13px;border:0;background:var(--gold);color:var(--ink);font-size:15px;font-weight:600;font-family:var(--font-display)}.cta:disabled{opacity:.45}.skel{background:linear-gradient(90deg,#eef2f4 25%,#f7fafb,#eef2f4 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:8px}@keyframes shimmer{to{background-position:-200% 0}}.mobile-nav{display:none}@media (max-width: 880px){.sidebar{display:none}.main{margin-left:0}.topbar{padding:12px 16px}.content{padding:16px 14px 96px}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--ink);padding:8px 6px calc(8px + env(safe-area-inset-bottom));justify-content:space-around}.mobile-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;color:#8ea2b1;font-size:10px;font-weight:500;padding:4px 8px;border-radius:8px}.mobile-nav a.active{color:#fff}.mobile-nav .ico{width:21px;height:21px}.kpi-value{font-size:22px}}
