:root{--c-ink:#243b53;--c-ink-dim:#334e68;--c-text-2:#627d98;--c-text-3:#829ab1;--c-text-4:#9fb3c8;--c-line:#e6ecf2;--c-line-2:#d9e2ec;--c-bg:#f5f7fa;--c-bg-2:#f8fafc;--c-bg-3:#fbfcfd;--c-bg-4:#f0f4f8;--c-white:#fff;--c-side:#102a43;--c-side-2:#1a3859;--c-side-line:#294b66;--c-side-text:#d9e2ec;--c-side-text-2:#9fb3c8;--c-side-text-3:#b8c7d9;--c-blue:#2563a7;--c-blue-700:#1f538c;--c-blue-50:#dceefb;--c-blue-25:#e8f1f8;--c-amber:#b7791f;--c-amber-50:#fff3cd;--c-red:#ba2525;--c-red-50:#ffe3e3;--c-green:#147d64;--c-green-50:#d8f3e7;--c-purple:#6b46c1;--c-purple-50:#eae2ff;--r-sm:4px;--r-md:6px;--r-lg:8px;--r-xl:12px;--r-pill:999px;--shadow-card:0 1px 2px #243b530a;--shadow-pop:0 12px 32px #102a4329, 0 2px 8px #102a4314;--font-cn:"Noto Sans SC", "PingFang SC", "Microsoft YaHei", system-ui, -apple-system, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--font-cn);color:var(--c-ink);background:var(--c-bg);-webkit-font-smoothing:antialiased;margin:0;font-size:13px;line-height:1.5}button{cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}input,textarea,select{font-family:inherit}.shell{background:var(--c-bg);grid-template-columns:238px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--c-side);color:var(--c-side-text);z-index:20;flex-direction:column;gap:4px;height:100vh;padding:28px 14px 24px;display:flex;position:sticky;top:0}.sidebar .brand{margin-bottom:6px;padding:0 10px}.sidebar .brand h1{color:var(--c-white);letter-spacing:.2px;margin:0 0 6px;font-size:22px;font-weight:700;line-height:1.18}.sidebar .brand .role{color:var(--c-side-text-3);font-size:12px;font-weight:500}.sidebar .group-label{color:var(--c-side-text-2);letter-spacing:.8px;text-transform:uppercase;margin:18px 12px 6px;font-size:11px;font-weight:600}.nav-item{color:var(--c-side-text);text-align:left;cursor:pointer;white-space:nowrap;background:0 0;border:0;border-radius:6px;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:13px;font-weight:500;transition:background .12s,color .12s;display:flex}.nav-item .nav-ic{opacity:.75;flex:0 0 16px;justify-content:center;align-items:center;height:16px;display:inline-flex}.nav-item:hover{color:#fff;background:#ffffff0f}.nav-item.is-active{color:#fff;background:#ffffff1f}.nav-item.is-active .nav-ic{opacity:1}.nav-item .badge-num{color:#fff;background:#ffffff24;border-radius:999px;margin-left:auto;padding:1px 7px;font-size:11px;font-weight:600}.sidebar .user{border-top:1px solid var(--c-side-line);margin-top:auto;padding:16px 12px 0}.sidebar .user .email{color:var(--c-side-text);font-size:12px;font-weight:500}.sidebar .user .role{color:var(--c-side-text-2);margin-top:2px;font-size:11px}.main{flex-direction:column;min-width:0;display:flex}.topbar{z-index:10;background:var(--c-white);border-bottom:1px solid var(--c-line);align-items:center;gap:16px;padding:16px 32px;display:flex;position:sticky;top:0}.topbar .titles{flex:1;min-width:0}.topbar h2{color:var(--c-ink);letter-spacing:.2px;margin:0;font-size:20px;font-weight:700}.topbar .subtitle{color:var(--c-text-2);margin-top:2px;font-size:12px}.topbar .search{border:1px solid var(--c-line);width:220px;height:36px;color:var(--c-ink);background:#f7fafc url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23829AB1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") 10px no-repeat;border-radius:6px;outline:none;padding:0 12px 0 32px;font-size:12px}.topbar .search::placeholder{color:var(--c-text-3)}.topbar .topbar-actions{align-items:center;gap:10px;display:flex}.content{flex-direction:column;gap:20px;width:100%;max-width:1440px;margin:0 auto;padding:28px 32px 64px;display:flex}.card{background:var(--c-white);border:1px solid var(--c-line);box-shadow:var(--shadow-card);border-radius:8px}.card.pad{padding:22px 24px}.card.pad-lg{padding:26px 28px}.card-head{flex-wrap:wrap;align-items:baseline;gap:12px;margin-bottom:14px;display:flex}.card-head h3{color:var(--c-ink);letter-spacing:.1px;white-space:nowrap;flex-shrink:0;margin:0;font-size:18px;font-weight:700}.card-head .head-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.card-head .head-sub{color:var(--c-text-2);font-size:12px}.metric{background:var(--c-white);border:1px solid var(--c-line);border-left:4px solid var(--c-blue);box-shadow:var(--shadow-card);border-radius:8px;flex-direction:column;gap:6px;padding:18px 22px;display:flex}.metric.red{border-left-color:var(--c-red)}.metric.amber{border-left-color:var(--c-amber)}.metric.purple{border-left-color:var(--c-purple)}.metric.green{border-left-color:var(--c-green)}.metric .m-title{color:var(--c-text-2);letter-spacing:.2px;font-size:12px;font-weight:500}.metric .m-value{color:var(--c-ink);font-variant-numeric:tabular-nums;font-size:32px;font-weight:700;line-height:1.1}.metric .m-detail{color:var(--c-text-2);font-size:12px;line-height:1.4}.metric.compact .m-value{font-size:26px}.tag{letter-spacing:.1px;white-space:nowrap;border-radius:999px;align-items:center;gap:5px;height:24px;padding:0 10px;font-size:11px;font-weight:500;display:inline-flex}.tag.blue{background:var(--c-blue-50);color:var(--c-blue)}.tag.amber{background:var(--c-amber-50);color:var(--c-amber)}.tag.red{background:var(--c-red-50);color:var(--c-red)}.tag.green{background:var(--c-green-50);color:var(--c-green)}.tag.purple{background:var(--c-purple-50);color:var(--c-purple)}.tag.gray{background:var(--c-bg-4);color:var(--c-text-2)}.tag .dot{opacity:.85;background:currentColor;border-radius:50%;width:6px;height:6px}.btn{border:1px solid var(--c-line-2);height:36px;color:var(--c-ink);white-space:nowrap;background:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;padding:0 16px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.btn:hover{background:var(--c-bg-2);border-color:var(--c-text-4)}.btn.primary{background:var(--c-blue);border-color:var(--c-blue);color:#fff}.btn.primary:hover{background:var(--c-blue-700);border-color:var(--c-blue-700)}.btn.danger{background:var(--c-red);border-color:var(--c-red);color:#fff}.btn.danger:hover{background:#9b1c1c;border-color:#9b1c1c}.btn.ghost{background:0 0;border-color:#0000}.btn.ghost:hover{background:var(--c-bg-4)}.btn.sm{height:30px;padding:0 12px;font-size:12px}.btn.lg{height:42px;padding:0 20px;font-size:14px}.field{flex-direction:column;gap:6px;display:flex}.field .label{color:var(--c-text-2);font-size:12px;font-weight:500}.field .input,.field .display{background:var(--c-bg-3);border:1px solid var(--c-line-2);height:42px;color:var(--c-ink);border-radius:6px;outline:none;align-items:center;padding:0 12px;font-size:13px;display:flex}.field .input:focus{border-color:var(--c-blue);background:#fff}.field textarea.input{resize:vertical;height:96px;padding:10px 12px}.check{cursor:pointer;color:var(--c-ink);align-items:flex-start;gap:10px;font-size:13px;font-weight:500;line-height:1.5;display:flex}.check>span:last-child{flex:1;min-width:0}.check input{opacity:0;pointer-events:none;position:absolute}.check .box{border:1px solid var(--c-line-2);background:#fff;border-radius:4px;flex:0 0 18px;justify-content:center;align-items:center;width:18px;height:18px;margin-top:1px;transition:background .12s,border-color .12s;display:inline-flex}.check .box:after{content:"";opacity:0;border-bottom:2px solid #fff;border-right:2px solid #fff;width:5px;height:9px;transform:rotate(45deg)translate(-.5px,-.5px)}.check.checked .box,.check input:checked+.box{background:var(--c-blue);border-color:var(--c-blue)}.check.checked .box:after,.check input:checked+.box:after{opacity:1}.tbl{border-collapse:collapse;width:100%;font-size:12px}.tbl thead th{letter-spacing:.4px;color:var(--c-text-2);text-transform:uppercase;border-bottom:1px solid var(--c-line);text-align:left;background:#f7fafc;padding:12px 16px;font-size:11px;font-weight:500}.tbl tbody td{border-bottom:1px solid var(--c-line);color:var(--c-ink);vertical-align:middle;padding:14px 16px}.tbl tbody tr:last-child td{border-bottom:0}.tbl tbody tr:hover td{background:var(--c-bg-2)}.tbl .muted{color:var(--c-text-2)}.tbl td.actions{text-align:right}.tbl tr.clickable{cursor:pointer}.bar{background:var(--c-line);border-radius:4px;height:8px;position:relative;overflow:hidden}.bar>i{background:var(--c-blue);border-radius:4px;height:100%;display:block}.bar.amber>i{background:var(--c-amber)}.bar.red>i{background:var(--c-red)}.bar.green>i{background:var(--c-green)}.chain{flex-direction:column;gap:16px;padding-left:4px;display:flex;position:relative}.chain-row{grid-template-columns:24px 1fr auto;align-items:center;gap:12px;display:grid;position:relative}.chain-row .dot{background:var(--c-green);z-index:1;border-radius:50%;width:12px;height:12px;margin-left:6px;position:relative;box-shadow:0 0 0 3px #fff}.chain-row .dot.gray{background:var(--c-line-2)}.chain-row .dot.amber{background:var(--c-amber)}.chain-row .dot.blue{background:var(--c-blue)}.chain-row .dot.hollow{border:2px solid var(--c-line-2);background:#fff}.chain:before{content:"";background:var(--c-line);width:2px;position:absolute;top:8px;bottom:8px;left:10px}.chain-row .who{color:var(--c-ink);font-size:13px;font-weight:500}.chain-row .when{color:var(--c-text-3);margin-top:2px;font-size:11px}.timeline{flex-direction:column;gap:14px;padding-left:4px;display:flex;position:relative}.timeline-row{grid-template-columns:22px 80px 1fr auto;align-items:start;gap:14px;display:grid;position:relative}.timeline-row .tl-dot{background:var(--c-blue);z-index:1;border-radius:50%;width:10px;height:10px;margin:6px 0 0 6px;box-shadow:0 0 0 3px #fff}.timeline-row.future .tl-dot{background:var(--c-line-2)}.timeline:before{content:"";background:var(--c-line);width:2px;position:absolute;top:8px;bottom:8px;left:10px}.timeline-row .tl-time{color:var(--c-text-2);padding-top:2px;font-size:12px;font-weight:500}.timeline-row .tl-body{color:var(--c-ink);padding-top:1px;font-size:13px;line-height:1.5}.timeline-row.future .tl-body{color:var(--c-text-3)}.row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.col{flex-direction:column;gap:12px;display:flex}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;display:grid}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;display:grid}.gap-20{gap:20px}.gap-16{gap:16px}.gap-12{gap:12px}.gap-8{gap:8px}.muted{color:var(--c-text-2)}.muted-2{color:var(--c-text-3)}.strong{color:var(--c-ink);font-weight:600}.divider{background:var(--c-line);height:1px;margin:16px 0}.divider.v{background:var(--c-line-2);align-self:stretch;width:1px;height:auto;min-height:32px;margin:0}.page-id{color:var(--c-ink);letter-spacing:.4px;font-variant-numeric:tabular-nums;font-size:28px;font-weight:700}.kv{grid-template-columns:100px 1fr;gap:8px 16px;font-size:13px;display:grid}.kv dt{color:var(--c-text-2);font-weight:500}.kv dd{color:var(--c-ink);margin:0}.email-card{border:1px solid var(--c-line);background:var(--c-bg-3);border-radius:6px;padding:14px 16px}.email-row{border-bottom:1px solid var(--c-line);grid-template-columns:64px 60px 1fr;align-items:center;gap:14px;padding:10px 0;font-size:13px;display:grid}.email-row:last-child{border-bottom:0}.user-pill{border:1px solid var(--c-line);color:var(--c-ink-dim);white-space:nowrap;background:#fff;border-radius:999px;align-items:center;gap:8px;padding:4px 12px 4px 4px;font-size:12px;font-weight:500;display:inline-flex}.user-pill .avatar{background:var(--c-side);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:600;display:inline-flex}.mobile-tabbar,.mobile-topbar,.menu-btn{display:none}@media (width<=1024px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3,.grid-2{grid-template-columns:1fr}}@media (width<=768px){.shell{grid-template-columns:1fr}.sidebar{display:none}.sidebar.is-open{z-index:100;height:100vh;box-shadow:var(--shadow-pop);display:flex;position:fixed;inset:0 30% 0 0}.menu-btn{border:1px solid var(--c-line);width:36px;height:36px;color:var(--c-ink);background:#fff;border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.topbar{gap:10px;padding:12px 16px}.topbar h2{font-size:16px}.topbar .subtitle,.topbar .search{display:none}.content{gap:14px;padding:16px 16px 110px}.card.pad,.card.pad-lg{padding:18px 16px}.page-id{word-break:break-all;font-size:20px;line-height:1.25}.grid-4,.grid-3,.grid-2{grid-template-columns:1fr;gap:12px}.metric{padding:14px 16px 14px 20px}.metric .m-value{font-size:26px}.kv{grid-template-columns:90px 1fr}.chain-row{grid-template-columns:24px 1fr auto}.timeline-row{grid-template-columns:22px 60px 1fr}.timeline-row>.tl-end-tag,.tbl thead{display:none}.tbl tbody td{border-bottom:0;padding:4px 16px;display:block}.tbl tbody tr{border-bottom:1px solid var(--c-line);padding:12px 0;display:block}.tbl tbody tr:last-child{border-bottom:0}.tbl tbody td:first-child{padding-top:12px;font-weight:600}.tbl tbody td.actions{text-align:left;padding-top:8px}.mobile-tabbar{border-top:1px solid var(--c-line);z-index:30;height:64px;padding:6px 4px env(safe-area-inset-bottom);background:#fff;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-tabbar button{color:var(--c-text-2);background:0 0;border:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:4px 0;font-size:10px;font-weight:500;display:flex}.mobile-tabbar button.is-active{color:var(--c-blue)}.mobile-tabbar button .tab-ic{width:22px;height:22px}}.drawer-backdrop{display:none}@media (width<=768px){.drawer-backdrop.is-open{z-index:90;background:#102a4380;display:block;position:fixed;inset:0}}.countdown{background:var(--c-amber-50);color:var(--c-amber);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:500;display:inline-flex}.countdown.urgent{background:var(--c-red-50);color:var(--c-red)}.countdown.ok{background:var(--c-green-50);color:var(--c-green)}.countdown .pulse{background:currentColor;border-radius:50%;width:6px;height:6px;animation:1.6s ease-out infinite pulse;box-shadow:0 0}@keyframes pulse{0%{box-shadow:0 0}70%{box-shadow:0 0 0 6px #0000}to{box-shadow:0 0 #0000}}.scroll-x{overflow-x:auto}.scroll-x::-webkit-scrollbar{height:6px}.scroll-x::-webkit-scrollbar-thumb{background:var(--c-line-2);border-radius:999px}.ic{justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex}.ic svg{width:100%;height:100%}.status-strip{flex-wrap:wrap;gap:8px;display:flex}.evid{border:1px solid var(--c-line);background:var(--c-bg-2);border-radius:8px;flex-direction:column;gap:10px;padding:14px 16px;display:flex}.evid .evid-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.evid .evid-title{color:var(--c-ink);font-size:13px;font-weight:600}.evid .evid-img{border:1px dashed var(--c-line-2);height:120px;color:var(--c-text-3);background:repeating-linear-gradient(135deg,#fff 0 8px,#f7fafc 8px 16px);border-radius:6px;justify-content:center;align-items:center;font-size:11px;display:flex}.evid .price{color:var(--c-blue);font-variant-numeric:tabular-nums;font-size:24px;font-weight:700}.evid .price.bad{color:var(--c-red)}.evid .meta{color:var(--c-text-3);font-size:11px}.safety-row{flex-direction:column;gap:6px;display:flex}.safety-row .top{justify-content:space-between;align-items:baseline;gap:12px;font-size:12px;display:flex}.safety-row .top .label{color:var(--c-ink);font-weight:500}.safety-row .top .max{color:var(--c-text-2);white-space:nowrap;flex-shrink:0;font-size:11px}.dropzone{border:1px dashed var(--c-line-2);background:var(--c-bg-2);text-align:center;color:var(--c-text-2);cursor:pointer;border-radius:8px;padding:28px 20px;font-size:13px;transition:border-color .15s,background .15s}.dropzone:hover,.dropzone.dragover{border-color:var(--c-blue);background:var(--c-blue-25);color:var(--c-blue)}.login-bg{background:linear-gradient(135deg, var(--c-side) 0%, #0a1929 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--c-white);width:100%;max-width:400px;box-shadow:var(--shadow-pop);border-radius:12px;padding:40px 36px}.login-brand{text-align:center;margin-bottom:32px}.login-brand h1{color:var(--c-ink);margin:0 0 6px;font-size:24px;font-weight:700}.login-brand .sub{color:var(--c-text-2);font-size:13px}.login-error{background:var(--c-red-50);color:var(--c-red);border-radius:6px;margin-bottom:16px;padding:10px 14px;font-size:12px}.login-footer{text-align:center;color:var(--c-text-3);margin-top:24px;font-size:11px}.lang-toggle{border:1px solid var(--c-line-2);height:30px;color:var(--c-ink-dim);cursor:pointer;white-space:nowrap;background:#fff;border-radius:999px;align-items:center;gap:4px;padding:0 12px;font-size:12px;font-weight:500;transition:background .12s,border-color .12s;display:inline-flex}.lang-toggle:hover{background:var(--c-bg-4);border-color:var(--c-text-4)}.log-actor{border-radius:999px;padding:3px 8px;font-size:11px;font-weight:500}.log-actor.system{background:var(--c-blue-50);color:var(--c-blue)}.log-actor.hotel{background:var(--c-amber-50);color:var(--c-amber)}.log-actor.hq{background:var(--c-purple-50);color:var(--c-purple)}.log-actor.email{background:var(--c-blue-50);color:var(--c-blue)}
