:root{--brand-50: #f5f5f5;--brand-100: #ebebeb;--brand-200: #d6d6d6;--brand-300: #b8b8b8;--brand-400: #8f8f8f;--brand-500: #666666;--brand-600: #333333;--brand-700: #1a1a1a;--brand-800: #111111;--blue-50: #f5f5f5;--blue-100: #ebebeb;--blue-200: #d6d6d6;--blue-500: #555555;--blue-600: #333333;--blue-700: #1a1a1a;--blue-800: #111111;--green-50: #f0f0f0;--green-100: #e0e0e0;--green-500: #555555;--green-600: #3a3a3a;--green-700: #2a2a2a;--white: #ffffff;--gray-50: #fafafa;--gray-100: #f4f4f4;--gray-200: #e8e8e8;--gray-300: #d1d1d1;--gray-400: #a8a8a8;--gray-500: #737373;--gray-600: #525252;--gray-700: #3d3d3d;--gray-800: #262626;--gray-900: #111111;--amber-50: #fffbeb;--amber-500: #f59e0b;--amber-600: #d97706;--red-50: #fef2f2;--red-500: #ef4444;--red-600: #dc2626;--purple-50: #faf5ff;--purple-500:#a855f7;--bg-app: #f5f5f5;--bg-surface: #ffffff;--text-primary: #111111;--text-secondary:#525252;--text-muted: #a8a8a8;--border: #e8e8e8;--sidebar-w: 268px;--sidebar-w-collapsed: 76px;--header-h: 64px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .06);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .14);--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg-app);color:var(--text-primary);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}ul{list-style:none}input,select,textarea{font-family:inherit;font-size:14px}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:20px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.muted{color:var(--text-muted)}.app-shell{display:flex;min-height:100vh}.main-wrap{flex:1;min-width:0;display:flex;flex-direction:column;margin-left:var(--sidebar-w);transition:margin-left .25s ease}.main-wrap.collapsed{margin-left:var(--sidebar-w-collapsed)}.content{flex:1;padding:24px 28px 40px;max-width:1600px;width:100%;margin:0 auto}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:linear-gradient(180deg,#0a0a0a,#1a1a1a);color:silver;display:flex;flex-direction:column;z-index:50;transition:width .25s ease,transform .25s ease}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.sidebar-brand{height:var(--header-h);display:flex;align-items:center;gap:12px;padding:0 20px;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0}.sidebar-brand img{width:34px;height:34px;border-radius:9px}.sidebar-brand .brand-text{display:flex;flex-direction:column;line-height:1.1}.sidebar-brand .brand-text b{color:#fff;font-size:16px;font-weight:800;letter-spacing:-.3px}.sidebar-brand .brand-text span{font-size:11px;color:#787878}.sidebar.collapsed .brand-text{display:none}.sidebar-role{margin:14px 16px 6px;padding:10px 12px;background:#ffffff0d;border-radius:var(--radius-sm);display:flex;align-items:center;gap:10px}.sidebar-role .role-dot{width:32px;height:32px;border-radius:8px;background:#333;display:grid;place-items:center;color:#fff;flex-shrink:0}.sidebar-role .role-meta{line-height:1.2;min-width:0}.sidebar-role .role-meta b{color:#fff;font-size:13px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-role .role-meta span{font-size:11px;color:#787878}.sidebar.collapsed .sidebar-role{justify-content:center}.sidebar.collapsed .sidebar-role .role-meta{display:none}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 12px 20px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1f}.nav-group-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;color:#555;font-weight:700;padding:16px 12px 6px}.sidebar.collapsed .nav-group-label{text-align:center;padding:14px 0 4px;font-size:9px}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:var(--radius-sm);color:#b0b0b0;font-size:13.5px;font-weight:500;cursor:pointer;transition:background .15s,color .15s;position:relative;-webkit-user-select:none;user-select:none}.nav-item:hover{background:#ffffff12;color:#fff}.nav-item.active{background:#333;color:#fff;box-shadow:var(--shadow-sm)}.nav-item .nav-icon{flex-shrink:0;display:grid;place-items:center}.nav-item .nav-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item .nav-chevron{transition:transform .2s;flex-shrink:0}.nav-item .nav-chevron.open{transform:rotate(90deg)}.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-chevron{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:11px}.nav-sub{margin:2px 0 2px 14px;padding-left:12px;border-left:1px solid rgba(255,255,255,.08);overflow:hidden}.nav-subitem{display:block;padding:7px 12px;border-radius:7px;color:#888;font-size:13px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.nav-subitem:hover{background:#ffffff0f;color:#fff}.nav-subitem.active{color:#fff;background:#ffffff1f;font-weight:600}.sidebar.collapsed .nav-sub{display:none}.header{height:var(--header-h);background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 24px;position:sticky;top:0;z-index:40}.icon-btn{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:var(--gray-600);position:relative;transition:background .15s,color .15s}.icon-btn:hover{background:var(--gray-100);color:var(--gray-900)}.header-search{flex:1;max-width:460px;display:flex;align-items:center;gap:10px;background:var(--gray-100);border:1px solid transparent;border-radius:10px;padding:0 14px;height:40px;transition:border .15s,background .15s}.header-search:focus-within{background:#fff;border-color:var(--gray-300);box-shadow:0 0 0 3px var(--gray-100)}.header-search input{border:none;background:none;outline:none;flex:1;color:var(--text-primary)}.header-search .kbd{font-size:11px;color:var(--text-muted);border:1px solid var(--border);border-radius:5px;padding:1px 6px;background:#fff}.badge-dot{position:absolute;top:7px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--red-500);border:2px solid #fff}.profile-chip{display:flex;align-items:center;gap:10px;padding:5px 10px 5px 5px;border-radius:10px;transition:background .15s}.profile-chip:hover{background:var(--gray-100)}.avatar{width:36px;height:36px;border-radius:10px;background:#222;color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0}.profile-chip .pf-meta{line-height:1.2;text-align:left}.profile-chip .pf-meta b{font-size:13px;display:block}.profile-chip .pf-meta span{font-size:11.5px;color:var(--text-muted)}.dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:240px;padding:8px;z-index:60;animation:pop .14s ease}@keyframes pop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.dropdown-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--text-secondary);font-size:13.5px;width:100%;text-align:left}.dropdown-item:hover{background:var(--gray-100);color:var(--gray-900)}.dropdown-item.danger:hover{background:var(--red-50);color:var(--red-600)}.dropdown-head{padding:10px 12px;border-bottom:1px solid var(--border);margin-bottom:6px}.dropdown-divider{height:1px;background:var(--border);margin:6px 0}.notif-item{display:flex;gap:10px;padding:10px 12px;border-radius:8px;align-items:flex-start}.notif-item:hover{background:var(--gray-100)}.notif-item .notif-icon{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex-shrink:0}.notif-item p{font-size:13px;color:var(--text-primary)}.notif-item small{font-size:11.5px;color:var(--text-muted)}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text-muted);margin-bottom:4px}.breadcrumb a:hover{color:var(--gray-900)}.breadcrumb .crumb-current{color:var(--text-secondary);font-weight:600}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}.page-head h1{font-size:22px;font-weight:800;letter-spacing:-.4px}.page-head p{color:var(--text-secondary);font-size:13.5px;margin-top:2px}.page-head-actions{display:flex;gap:10px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:10px;font-size:13.5px;font-weight:600;transition:all .15s;white-space:nowrap}.btn-primary{background:#111;color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:#333;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-success{background:#333;color:#fff}.btn-success:hover{background:#1a1a1a;transform:translateY(-1px)}.btn-ghost{background:#fff;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{border-color:var(--gray-400);color:var(--gray-900);background:var(--gray-50)}.btn-sm{padding:6px 12px;font-size:12.5px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-xs)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border)}.card-head h3{font-size:15px;font-weight:700}.card-head p{font-size:12.5px;color:var(--text-muted)}.card-body{padding:20px}.stat-grid{display:grid;gap:18px;margin-bottom:24px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-xs);transition:transform .18s,box-shadow .18s;position:relative;overflow:hidden}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.stat-card:after{content:"";position:absolute;right:-20px;top:-20px;width:90px;height:90px;border-radius:50%;background:var(--accent, var(--gray-100));opacity:.5}.stat-card .stat-top{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}.stat-icon{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;color:#fff}.stat-card .stat-value{font-size:28px;font-weight:800;letter-spacing:-.5px;margin-top:14px;position:relative;z-index:1}.stat-card .stat-label{color:var(--text-secondary);font-size:13px;position:relative;z-index:1}.stat-trend{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:700;padding:3px 8px;border-radius:20px;margin-top:10px}.stat-trend.up{background:#f0f0f0;color:#333}.stat-trend.down{background:var(--red-50);color:var(--red-600)}.grid{display:grid;gap:20px}.grid-2{grid-template-columns:2fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.chart-wrap{width:100%;height:280px}.chart-placeholder{height:240px;border-radius:var(--radius-sm);background:repeating-linear-gradient(90deg,var(--gray-100),var(--gray-100) 1px,transparent 1px,transparent 48px),repeating-linear-gradient(0deg,var(--gray-100),var(--gray-100) 1px,transparent 1px,transparent 48px),var(--gray-50);display:grid;place-items:center;color:var(--text-muted);border:1px dashed var(--border)}.table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;flex-wrap:wrap}.table-search{display:flex;align-items:center;gap:8px;background:var(--gray-100);border:1px solid transparent;border-radius:9px;padding:0 12px;height:38px;min-width:220px}.table-search:focus-within{background:#fff;border-color:var(--gray-300)}.table-search input{border:none;background:none;outline:none;flex:1}.table-filters{display:flex;gap:10px;flex-wrap:wrap}.select-input{height:38px;border:1px solid var(--border);border-radius:9px;padding:0 12px;background:#fff;color:var(--text-secondary);cursor:pointer}.select-input:focus{outline:none;border-color:var(--gray-400)}.table-scroll{overflow-x:auto}table.data-table{width:100%;border-collapse:collapse;font-size:13.5px}table.data-table thead th{text-align:left;padding:12px 20px;background:var(--gray-50);color:var(--text-secondary);font-weight:700;font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}table.data-table thead th:hover{color:var(--gray-900)}table.data-table tbody td{padding:13px 20px;border-bottom:1px solid var(--gray-100);color:var(--text-secondary);white-space:nowrap}table.data-table tbody tr{transition:background .12s}table.data-table tbody tr:hover{background:var(--gray-50)}table.data-table tbody tr:last-child td{border-bottom:none}table.data-table td .cell-strong{color:var(--text-primary);font-weight:600}.row-id{font-family:ui-monospace,SF Mono,monospace;font-size:12.5px;color:var(--gray-700);font-weight:600}.table-foot{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--border);flex-wrap:wrap;gap:10px}.pagination{display:flex;gap:5px}.page-btn{min-width:32px;height:32px;padding:0 8px;border-radius:8px;border:1px solid var(--border);color:var(--text-secondary);font-weight:600;display:grid;place-items:center}.page-btn:hover:not(:disabled){border-color:var(--gray-400);color:var(--gray-900)}.page-btn.active{background:#111;color:#fff;border-color:#111}.page-btn:disabled{opacity:.45;cursor:not-allowed}.empty-state{padding:50px 20px;text-align:center;color:var(--text-muted)}.empty-state .empty-icon{width:56px;height:56px;border-radius:16px;background:var(--gray-100);display:grid;place-items:center;margin:0 auto 14px;color:var(--gray-400)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.badge.green{background:#e8f5e9;color:#2e7d32}.badge.blue{background:#f0f0f0;color:#333}.badge.amber{background:var(--amber-50);color:var(--amber-600)}.badge.red{background:var(--red-50);color:var(--red-600)}.badge.gray{background:var(--gray-100);color:var(--gray-500)}.badge.purple{background:var(--purple-50);color:var(--purple-500)}.timeline{position:relative;padding-left:28px}.timeline:before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--border)}.timeline-item{position:relative;padding-bottom:22px}.timeline-item:before{content:"";position:absolute;left:-24px;top:3px;width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid #333333}.timeline-item.green:before{border-color:#2e7d32}.timeline-item.amber:before{border-color:var(--amber-500)}.timeline-item .tl-time{font-size:12px;color:var(--text-muted)}.timeline-item .tl-title{font-weight:600;color:var(--text-primary);margin:2px 0}.timeline-item .tl-desc{font-size:13px;color:var(--text-secondary)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field.full{grid-column:1 / -1}.form-field label{font-size:13px;font-weight:600;color:var(--text-secondary)}.form-field label .req{color:var(--red-500)}.form-control{height:42px;border:1px solid var(--border);border-radius:10px;padding:0 14px;background:#fff;color:var(--text-primary);transition:border .15s,box-shadow .15s}textarea.form-control{height:auto;padding:12px 14px;resize:vertical;min-height:90px}.form-control:focus{outline:none;border-color:var(--gray-400);box-shadow:0 0 0 3px var(--gray-100)}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.form-hint{font-size:12px;color:var(--text-muted)}.login-page{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}.login-hero{background:linear-gradient(135deg,#0a0a0a,#1a1a1a 55%,#2a2a2a 140%);color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.login-hero:before,.login-hero:after{content:"";position:absolute;border-radius:50%;background:#ffffff0a}.login-hero:before{width:360px;height:360px;right:-120px;top:-100px}.login-hero:after{width:240px;height:240px;left:-80px;bottom:-60px;background:#ffffff0f}.login-hero .lh-brand{display:flex;align-items:center;gap:12px;position:relative;z-index:1}.login-hero .lh-brand img{width:44px;height:44px;border-radius:11px}.login-hero .lh-brand b{font-size:22px;font-weight:800}.login-hero .lh-mid{position:relative;z-index:1}.login-hero .lh-mid h2{font-size:36px;font-weight:800;line-height:1.15;letter-spacing:-.8px}.login-hero .lh-mid p{margin-top:16px;font-size:15px;color:#a0a0a0;max-width:420px;line-height:1.6}.login-features{display:flex;flex-direction:column;gap:14px;margin-top:30px}.login-features .lf{display:flex;align-items:center;gap:12px;font-size:14px;color:#c8c8c8}.login-features .lf .lf-ic{width:34px;height:34px;border-radius:10px;background:#ffffff1a;display:grid;place-items:center}.login-hero .lh-foot{position:relative;z-index:1;font-size:13px;color:#666}.login-form-side{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg-surface)}.login-card{width:100%;max-width:400px}.login-card h1{font-size:26px;font-weight:800;letter-spacing:-.5px}.login-card .sub{color:var(--text-secondary);margin-top:6px;margin-bottom:28px}.login-field{margin-bottom:18px}.login-field label{display:block;font-size:13px;font-weight:600;margin-bottom:7px;color:var(--text-secondary)}.input-wrap{display:flex;align-items:center;gap:10px;height:46px;border:1px solid var(--border);border-radius:11px;padding:0 14px;background:#fff;transition:border .15s,box-shadow .15s}.input-wrap:focus-within{border-color:var(--gray-400);box-shadow:0 0 0 3px var(--gray-100)}.input-wrap input{border:none;outline:none;flex:1;background:none;height:100%}.input-wrap .eye{color:var(--text-muted);cursor:pointer}.login-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}.checkbox input{width:16px;height:16px;accent-color:#111111}.link{color:#333;font-weight:600;font-size:13px}.link:hover{text-decoration:underline}.btn-block{width:100%;justify-content:center;height:46px;font-size:15px}.role-picker{margin-top:24px}.role-picker .rp-label{font-size:12px;color:var(--text-muted);text-align:center;margin-bottom:12px;position:relative}.role-picker .rp-label span{background:#fff;padding:0 12px;position:relative;z-index:1}.role-picker .rp-label:before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:var(--border)}.role-options{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.role-opt{border:1px solid var(--border);border-radius:11px;padding:12px 8px;text-align:center;transition:all .15s}.role-opt:hover{border-color:var(--gray-400);background:var(--gray-50)}.role-opt.active{border-color:#111;background:var(--gray-50);box-shadow:0 0 0 3px var(--gray-100)}.role-opt .ro-ic{width:32px;height:32px;border-radius:9px;margin:0 auto 6px;display:grid;place-items:center;color:#fff}.role-opt b{font-size:12px;display:block;color:var(--text-primary)}.sidebar-overlay,.mobile-only{display:none}@media (max-width: 1100px){.grid-2,.grid-3{grid-template-columns:1fr}}@media (max-width: 1024px){.login-page{grid-template-columns:1fr}.login-hero{display:none}}@media (max-width: 900px){.mobile-only{display:grid}.main-wrap,.main-wrap.collapsed{margin-left:0}.sidebar{transform:translate(-100%);width:var(--sidebar-w)}.sidebar.mobile-open{transform:translate(0);box-shadow:var(--shadow-lg)}.sidebar.collapsed{width:var(--sidebar-w)}.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-chevron,.sidebar.collapsed .brand-text,.sidebar.collapsed .role-meta{display:block}.sidebar-overlay.show{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:45}.content{padding:18px 16px 32px}.header-search .kbd{display:none}.header-search{max-width:none}}@media (max-width: 560px){.stat-grid{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}.profile-chip .pf-meta{display:none}.page-head h1{font-size:19px}}.hero-gif-wrap{display:flex;flex-direction:column}.hero-gif{max-width:200px;width:100%;border-radius:14px}.role-card{display:flex;align-items:center;gap:16px;padding:16px 20px;border:1.5px solid var(--border);border-radius:var(--radius);background:#fff;text-align:left;width:100%;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}.role-card:hover{border-color:#111;box-shadow:var(--shadow-sm);transform:translate(3px)}.role-card-icon{width:44px;height:44px;border-radius:12px;background:#111;display:grid;place-items:center;color:#fff;flex-shrink:0}.role-card-info{flex:1}.role-card-info b{display:block;font-size:14px;font-weight:700;color:var(--text-primary)}.role-card-info span{font-size:12.5px;color:var(--text-muted)}.role-selected-chip{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:var(--gray-100);border-radius:9px;border:1px solid var(--border)}.role-selected-label{font-size:13px;font-weight:700;color:var(--text-primary)}.role-change-link{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;font-weight:600;color:var(--gray-500);transition:color .15s}.role-change-link:hover{color:var(--gray-900)}.form-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--red-50);border:1px solid #fca5a5;border-radius:9px;color:var(--red-600);font-size:13px;margin-bottom:16px}.form-success{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--green-50, #f0fdf4);border:1px solid #86efac;border-radius:9px;color:var(--green-600, #16a34a);font-size:13px;margin-bottom:16px}.spinner{width:32px;height:32px;border:3px solid var(--gray-200);border-top-color:#111;border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.po-table-wrap{overflow-x:auto}.po-table{width:100%;border-collapse:collapse;font-size:14px}.po-table th{background:var(--gray-50);color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.po-table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}.po-table tbody tr:last-child td{border-bottom:none}.po-table tbody tr:hover td{background:var(--gray-50)}.po-table .form-control{margin:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0f0f73;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.modal-box{background:#fff;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg, 0 20px 40px rgba(0, 0, 0, .2));width:100%;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border)}.modal-head h3{font-size:15px;font-weight:700}.modal-head p{font-size:12.5px;color:var(--text-muted);margin-top:2px}.modal-close{padding:6px}.modal-body{padding:20px;overflow-y:auto}.row-actions{display:flex;gap:6px}.row-action-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;font-size:12.5px;white-space:nowrap}.row-action-btn:disabled{opacity:.6;cursor:not-allowed}.summary-strip{display:flex;gap:16px}.summary-strip>div{flex:1;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg, 12px);padding:14px 18px;display:flex;flex-direction:column;gap:6px}.summary-strip .muted{font-size:12px}.invoice-print-wrap{display:none}.invoice-print-wrap.active{display:block}@media print{body *{visibility:hidden}.invoice-print-wrap,.invoice-print-wrap *{visibility:visible}.invoice-print-wrap{display:block!important;position:absolute;left:0;top:0;width:100%}}.invoice-doc{max-width:760px;margin:0 auto;padding:32px;font-size:13px;color:#111}.invoice-doc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;padding-bottom:20px;border-bottom:2px solid #111}.invoice-doc-brand{display:flex;align-items:center;gap:12px}.invoice-doc-brand img{height:48px;width:auto;object-fit:contain}.invoice-doc-company{font-size:16px;font-weight:700}.invoice-doc-meta{text-align:right}.invoice-doc-meta h2{font-size:22px;letter-spacing:1px;margin-bottom:8px}.invoice-doc-meta div{margin-top:2px}.invoice-doc-parties{padding:20px 0}.invoice-doc-table{width:100%;border-collapse:collapse;margin-top:8px}.invoice-doc-table th,.invoice-doc-table td{border:1px solid #ddd;padding:8px 10px;text-align:left;font-size:12.5px}.invoice-doc-table th{background:#f5f5f5;text-transform:uppercase;font-size:11px;letter-spacing:.4px}.invoice-doc-totals{width:280px;margin-left:auto;margin-top:16px}.invoice-doc-totals>div{display:flex;justify-content:space-between;padding:4px 0}.invoice-doc-grand{border-top:1px solid #111;margin-top:6px;padding-top:8px!important;font-weight:700;font-size:15px}.invoice-doc-balance{color:#b91c1c;font-weight:700}.invoice-doc-remarks{margin-top:20px;font-size:12.5px;color:#444}.invoice-doc-footer{margin-top:40px;text-align:center;font-size:11.5px;color:#888;border-top:1px solid #ddd;padding-top:12px}.summary-strip b{font-size:19px;font-weight:700}
