:root{--pt-primary: #4f46e5;--pt-primary-light: #6366f1;--pt-primary-dark: #4338ca;--pt-accent: #0ea5e9;--pt-sidebar-bg: #0f172a;--pt-sidebar-active: rgba(99, 102, 241, .18);--pt-page-bg: #f1f5f9;--pt-card-bg: #ffffff;--pt-text: #0f172a;--pt-text-secondary: #64748b;--pt-border: #e2e8f0;--pt-shadow: 0 1px 3px rgba(15, 23, 42, .06), 0 4px 20px rgba(15, 23, 42, .05);--pt-radius: 12px;--pt-radius-sm: 8px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%}body{font-family:PingFang SC,Microsoft YaHei,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--pt-page-bg);color:var(--pt-text);-webkit-font-smoothing:antialiased}a{color:var(--pt-primary);text-decoration:none;font-weight:500;transition:color .15s}a:hover{color:var(--pt-primary-light)}.layout{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:linear-gradient(180deg,#0f172a,#1e1b4b);color:#e2e8f0;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.06)}.sidebar__brand{display:flex;align-items:center;gap:12px;padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar__logo{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--pt-primary-light),var(--pt-accent));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar__title{font-size:15px;font-weight:700;color:#f8fafc;line-height:1.3}.sidebar__desc{font-size:11px;color:#64748b;margin-top:2px}.sidebar nav{flex:1;padding:12px 10px}.sidebar nav a{display:flex;align-items:center;gap:10px;padding:11px 14px;margin-bottom:4px;border-radius:var(--pt-radius-sm);color:#94a3b8;font-size:14px;font-weight:500;transition:background .15s,color .15s}.sidebar nav a:hover{background:#ffffff0f;color:#e2e8f0}.sidebar nav a.active{background:var(--pt-sidebar-active);color:#a5b4fc}.sidebar__footer{padding:16px;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:8px}.sidebar__settings{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;border:1px solid rgba(255,255,255,.1);border-radius:var(--pt-radius-sm);background:transparent;color:#94a3b8;font-size:13px;transition:background .15s,color .15s,border-color .15s}.sidebar__settings:hover,.sidebar__settings.active{background:#ffffff0f;color:#e2e8f0}.btn-logout{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;border:1px solid rgba(255,255,255,.1);border-radius:var(--pt-radius-sm);background:transparent;color:#94a3b8;font-size:13px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn-logout:hover{background:#ffffff0f;color:#e2e8f0;border-color:#ffffff26}.main-wrap{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:var(--pt-card-bg);border-bottom:1px solid var(--pt-border);flex-shrink:0}.topbar__title{font-size:18px;font-weight:600;color:var(--pt-text)}.topbar__badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;background:#eef2ff;color:var(--pt-primary);font-size:12px;font-weight:500}.main{flex:1;padding:24px 28px 32px;overflow:auto}.page-card{background:var(--pt-card-bg);border:1px solid var(--pt-border);border-radius:var(--pt-radius);box-shadow:var(--pt-shadow);overflow:hidden}.page-card+.page-card:not(.dashboard-split .page-card){margin-top:20px}.page-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 24px 0}.page-card__title{font-size:16px;font-weight:600;color:var(--pt-text)}.page-card__subtitle{margin-top:6px;font-size:13px;color:var(--pt-text-secondary);line-height:1.5}.page-card__extra{flex-shrink:0}.page-card__body{padding:20px 24px 24px;flex:1}.page-card__header+.page-card__body{padding-top:16px}.table-wrap{overflow-x:auto;border:1px solid var(--pt-border);border-radius:var(--pt-radius-sm)}table{width:100%;border-collapse:collapse;font-size:13px}th,td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--pt-border)}th{background:#f8fafc;font-weight:600;color:var(--pt-text-secondary);font-size:12px;text-transform:none;letter-spacing:.02em;white-space:nowrap}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#fafbff}td code,.user-tag{font-size:12px;padding:2px 8px;border-radius:4px;background:#eef2ff;color:var(--pt-primary-dark);font-family:ui-monospace,monospace}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:500;white-space:nowrap}.badge-in_stock{background:#dbeafe;color:#1d4ed8}.badge-outbound{background:#fef3c7;color:#b45309}.badge-partner_signed{background:#e0e7ff;color:#4338ca}.badge-activated{background:#d1fae5;color:#047857}.badge-maintenance{background:#fce7f3;color:#be185d}.role-badge{display:inline-flex;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:500;background:#f1f5f9;color:var(--pt-text-secondary)}.role-badge--admin{background:#fef3c7;color:#b45309}.role-badge--employee{background:#dbeafe;color:#1d4ed8}.role-badge--partner{background:#e0e7ff;color:#4338ca}.role-badge--user{background:#d1fae5;color:#047857}.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:16px 18px;background:#f8fafc;border:1px solid var(--pt-border);border-radius:var(--pt-radius-sm);margin-bottom:16px}.toolbar--plain{padding:0;background:none;border:none;margin-bottom:0}input[type=text],input[type=password],input:not([type]),select{padding:9px 12px;border:1px solid var(--pt-border);border-radius:var(--pt-radius-sm);font-size:13px;color:var(--pt-text);background:#fff;outline:none;transition:border-color .15s,box-shadow .15s;min-width:0}input:focus,select:focus{border-color:var(--pt-primary-light);box-shadow:0 0 0 3px #6366f11f}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}select.select-sm{padding:6px 28px 6px 10px;font-size:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border:none;border-radius:var(--pt-radius-sm);cursor:pointer;font-size:13px;font-weight:500;transition:background .15s,transform .1s;white-space:nowrap}.btn:active{transform:scale(.98)}.btn-primary{background:var(--pt-primary);color:#fff}.btn-primary:hover{background:var(--pt-primary-light)}.btn-sm{padding:7px 14px;font-size:12px;background:var(--pt-primary);color:#fff}.btn-sm:hover{background:var(--pt-primary-light)}.btn-ghost{background:#fff;color:var(--pt-text-secondary);border:1px solid var(--pt-border)}.btn-ghost:hover{background:#f8fafc;color:var(--pt-text)}.btn-danger-sm{padding:5px 12px;font-size:12px;background:#fff;color:#dc2626;border:1px solid #fecaca;border-radius:var(--pt-radius-sm);cursor:pointer;transition:background .15s,border-color .15s}.btn-danger-sm:hover{background:#fef2f2;border-color:#f87171}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{width:100%;max-width:420px;background:#fff;border-radius:var(--pt-radius);padding:24px;box-shadow:0 24px 48px #0000002e}.modal__title{font-size:17px;font-weight:600;margin-bottom:20px}.modal__actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.link-btn{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;font-size:13px;background:#eef2ff;color:var(--pt-primary);border:none;outline:none;cursor:pointer}.link-btn:hover{background:#e0e7ff;color:var(--pt-primary-dark)}.error{color:#dc2626;font-size:13px;margin-top:8px;padding:8px 12px;background:#fef2f2;border-radius:var(--pt-radius-sm)}.notice-banner{margin-bottom:16px;padding:16px 20px;border-radius:var(--pt-radius-md);border:1px solid #fcd34d;background:#fffbeb}.notice-banner--warning{border-color:#f59e0b;background:linear-gradient(180deg,#fffbeb,#fef3c7)}.notice-banner__title{font-weight:600;font-size:15px;color:#92400e;margin-bottom:8px}.notice-banner__body,.notice-banner__meta,.notice-banner__action{margin:0 0 8px;font-size:13px;line-height:1.6;color:#78350f}.notice-banner__action:last-child,.notice-banner__meta:last-child,.notice-banner__body:last-child{margin-bottom:0}.notice-banner__action .link-btn{margin-left:6px}.empty-state{text-align:center;padding:40px 20px;color:var(--pt-text-secondary);font-size:14px}.timeline{position:relative;padding-left:24px}.timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:var(--pt-border)}.timeline-item{position:relative;padding:0 0 20px 16px}.timeline-item:before{content:"";position:absolute;left:-21px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--pt-primary-light);border:2px solid #fff;box-shadow:0 0 0 2px var(--pt-primary-light)}.timeline-item:last-child{padding-bottom:0}.timeline-item strong{font-size:14px;color:var(--pt-text)}.timeline-item .time{font-size:12px;color:var(--pt-text-secondary);margin-top:4px}.timeline-item pre{margin-top:8px;padding:10px 12px;background:#f8fafc;border-radius:var(--pt-radius-sm);border:1px solid var(--pt-border);font-size:11px;overflow-x:auto;color:var(--pt-text-secondary)}.timeline-item--pending strong{color:var(--pt-text-secondary);font-weight:500}.timeline-item--pending:before{background:#e2e8f0;box-shadow:0 0 0 2px #e2e8f0}.meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.meta-item{padding:14px 16px;background:#f8fafc;border-radius:var(--pt-radius-sm);border:1px solid var(--pt-border)}.meta-item__label{font-size:12px;color:var(--pt-text-secondary);margin-bottom:4px}.meta-item__value{font-size:14px;font-weight:600;color:var(--pt-text)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#0f172a}.login-page__bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 60% at 15% 40%,rgba(99,102,241,.2),transparent),radial-gradient(ellipse 50% 50% at 85% 70%,rgba(14,165,233,.12),transparent),linear-gradient(160deg,#0f172a,#1e1b4b,#0f172a)}.login-page__orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.45}.login-page__orb--1{width:380px;height:380px;background:#6366f1;top:-80px;left:-80px}.login-page__orb--2{width:280px;height:280px;background:#0ea5e9;bottom:-60px;right:8%}.login-page__content{position:relative;z-index:1;display:flex;align-items:center;gap:64px;padding:40px;max-width:960px;width:100%}.login-hero{flex:1;color:#f8fafc}.login-hero__badge{display:inline-block;padding:4px 12px;border-radius:999px;background:#6366f126;border:1px solid rgba(99,102,241,.35);color:#a5b4fc;font-size:12px;letter-spacing:.5px;margin-bottom:20px}.login-hero__title{font-size:32px;font-weight:700;line-height:1.35;margin-bottom:16px}.login-hero__desc{font-size:14px;line-height:1.7;color:#94a3b8;max-width:400px;margin-bottom:24px}.login-hero__features{list-style:none;display:flex;flex-direction:column;gap:10px}.login-hero__features li{font-size:13px;color:#cbd5e1;padding-left:20px;position:relative}.login-hero__features li:before{content:"";position:absolute;left:0;top:7px;width:8px;height:8px;border-radius:50%;background:var(--pt-primary-light)}.login-box{width:380px;flex-shrink:0;background:#fff;border-radius:16px;padding:32px 32px 28px;box-shadow:0 24px 48px #00000040}.login-box__header{display:flex;align-items:center;gap:14px;margin-bottom:24px}.login-box__logo{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--pt-primary-light),var(--pt-accent));display:flex;align-items:center;justify-content:center;color:#fff}.login-box__title{font-size:18px;font-weight:600}.login-box__subtitle{font-size:12px;color:var(--pt-text-secondary);margin-top:2px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:var(--pt-text-secondary)}.form-group input{width:100%}.login-box .btn-primary{width:100%;margin-top:8px;padding:12px;font-size:15px;letter-spacing:1px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}.stat-grid--4{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.stat-card{background:var(--pt-page-bg);border:1px solid var(--pt-border);border-radius:var(--pt-radius-sm);padding:16px 18px;transition:box-shadow .15s,border-color .15s}.stat-card--link{text-decoration:none;color:inherit;display:block}.stat-card--link:hover{border-color:var(--pt-primary-light);box-shadow:var(--pt-shadow);color:inherit}.stat-card__label{font-size:12px;color:var(--pt-text-secondary);margin-bottom:6px}.stat-card__value{font-size:28px;font-weight:700;line-height:1.1;color:var(--pt-text)}.stat-card--accent{border-left:3px solid var(--pt-accent)}.stat-card--success{border-left:3px solid #16a34a}.stat-card--warn{border-left:3px solid #d97706}.stat-card--danger{border-left:3px solid #dc2626}.quick-links{display:flex;flex-wrap:wrap;gap:10px}.quick-link{display:inline-block;padding:8px 16px;background:var(--pt-page-bg);border:1px solid var(--pt-border);border-radius:20px;font-size:13px;transition:background .15s,border-color .15s}.quick-link:hover{background:#eef2ff;border-color:var(--pt-primary-light);color:var(--pt-primary)}.status-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.status-chip{border:1px solid var(--pt-border);background:#fff;border-radius:999px;padding:6px 12px;font-size:12px;color:var(--pt-text-secondary);cursor:pointer}.status-chip--active{border-color:var(--pt-primary);background:#eef2ff;color:var(--pt-primary)}.todo-list{display:flex;flex-direction:column;gap:10px}.todo-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-radius:var(--pt-radius-sm);border:1px solid var(--pt-border);text-decoration:none;color:inherit;transition:box-shadow .15s,border-color .15s}.todo-item:hover{box-shadow:var(--pt-shadow)}.todo-item--danger{border-left:4px solid #dc2626}.todo-item--warn{border-left:4px solid #d97706}.todo-item--accent{border-left:4px solid #2563eb}.todo-item__label{font-size:14px}.todo-item__count{font-size:20px;font-weight:700;min-width:32px;text-align:right}.dashboard-split{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:20px;margin:20px 0;align-items:stretch}.dashboard-split .page-card{height:100%}@media(max-width:960px){.dashboard-split{grid-template-columns:1fr}}.trend-legend{display:flex;gap:20px;margin-bottom:16px;font-size:13px;color:var(--pt-text-secondary)}.trend-legend__item{display:inline-flex;align-items:center;gap:6px}.trend-legend__dot{width:10px;height:10px;border-radius:2px}.trend-legend__dot--inbound{background:var(--pt-accent)}.trend-legend__dot--activated{background:#16a34a}.trend-chart{display:flex;align-items:flex-end;gap:8px;height:160px;padding-top:8px}.trend-chart__col{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;height:100%}.trend-chart__bars{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;gap:4px}.trend-chart__bar{width:40%;min-height:2px;border-radius:3px 3px 0 0;transition:height .2s}.trend-chart__bar--inbound{background:var(--pt-accent);opacity:.85}.trend-chart__bar--activated{background:#16a34a;opacity:.85}.trend-chart__values{display:flex;gap:6px;font-size:10px;color:var(--pt-text-secondary);margin-top:4px}.trend-chart__label{font-size:11px;color:var(--pt-text-secondary);margin-top:2px}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;padding-top:12px;border-top:1px solid var(--pt-border)}.pagination__info{font-size:13px;color:var(--pt-text-secondary)}.badge-session-failed{background:#fef2f2;color:#dc2626}.badge-session-completed{background:#f0fdf4;color:#16a34a}.toast-stack{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{min-width:240px;max-width:360px;padding:12px 16px;border-radius:var(--pt-radius-sm);font-size:14px;box-shadow:0 8px 24px #0f172a26;animation:toast-in .25s ease}.toast--success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.toast--error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.toast--info{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.table-actions{display:flex;gap:12px;flex-wrap:wrap}.row-inactive{opacity:.65}.badge-active{background:#f0fdf4;color:#16a34a}.badge-inactive{background:#f1f5f9;color:#64748b}.form-group--inline label{display:flex;align-items:center;font-size:13px;cursor:pointer}@media(max-width:860px){.login-page__content{flex-direction:column;gap:32px}.login-hero{text-align:center}.login-hero__desc{max-width:none}.login-hero__features{align-items:center}}
