:root{--bg-primary: #0f1117;--bg-secondary: #1a1d27;--bg-card: #21253a;--accent: #4f8ef7;--accent-secondary: #00d4aa;--text-primary: #e8eaf0;--text-secondary: #8b93a8;--border: #2d3147;--success: #22c55e;--error: #ef4444;--warning: #f59e0b;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--font-family: "Inter", system-ui, sans-serif;--transition: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}html,body,#root{height:100%}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-secondary)}img,svg{display:block;max-width:100%}h1,h2,h3,h4,h5,h6{line-height:1.3;color:var(--text-primary)}h1{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700}h2{font-size:clamp(1.2rem,3vw,1.75rem);font-weight:600}h3{font-size:1.15rem;font-weight:600}h4{font-size:1rem;font-weight:600}p{color:var(--text-secondary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}input,textarea,select{font-family:var(--font-family);background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);padding:9px 14px;border-radius:var(--radius-md);outline:none;transition:border-color var(--transition);width:100%;font-size:.88rem}input:focus,textarea:focus,select:focus{border-color:var(--accent)}input::placeholder,textarea::placeholder{color:var(--text-secondary)}select{-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;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='%238b93a8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}button{font-family:var(--font-family);cursor:pointer;border:none;border-radius:var(--radius-md);padding:10px 20px;font-size:.9rem;font-weight:500;display:inline-flex;align-items:center;gap:var(--spacing-sm);white-space:nowrap;transition:background var(--transition),color var(--transition),opacity var(--transition),transform var(--transition)}button:active{transform:scale(.97)}button:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:10px 20px;border-radius:var(--radius-md);font-family:var(--font-family);font-size:.9rem;font-weight:500;cursor:pointer;border:none;white-space:nowrap;text-decoration:none;transition:background var(--transition),color var(--transition),opacity var(--transition),transform var(--transition)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:linear-gradient(135deg,var(--accent),#3a6fd4);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#6aa3ff,var(--accent));color:#fff}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-card);border-color:var(--accent);color:var(--text-primary)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover{background:#ffffff0f;color:var(--text-primary);border-color:var(--border)}.btn-success{background:linear-gradient(135deg,var(--accent-secondary),#00a88a);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#00e5b8,var(--accent-secondary));color:#fff}.btn-danger{background:transparent;color:var(--error);border:1px solid rgba(239,68,68,.4)}.btn-danger:hover{background:#ef44441a}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.badge-cyan,.badge-primary{background:#4f8ef726;color:var(--accent);border:1px solid rgba(79,142,247,.3)}.badge-green,.badge-success{background:#22c55e26;color:var(--success);border:1px solid rgba(34,197,94,.3)}.badge-amber,.badge-warning{background:#f59e0b26;color:var(--warning);border:1px solid rgba(245,158,11,.3)}.badge-red,.badge-error{background:#ef444426;color:var(--error);border:1px solid rgba(239,68,68,.3)}.badge-muted,.badge-secondary{background:#8b93a826;color:var(--text-secondary);border:1px solid var(--border)}.type-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.72rem;font-weight:700;text-transform:uppercase}.tag-cpu,.type-badge-CPU{background:#f59e0b26;color:var(--warning)}.tag-ps,.type-badge-PS{background:#22c55e26;color:var(--success)}.tag-cp,.type-badge-CP{background:#ef444426;color:var(--error)}.tag-dp,.type-badge-SM{background:#8b93a826;color:var(--text-secondary)}.tag-pn{background:#4f8ef71f;color:var(--accent)}.table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:.85rem}thead th{background:var(--bg-secondary);color:var(--text-secondary);text-transform:uppercase;font-size:.72rem;letter-spacing:.08em;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}tbody tr{transition:background var(--transition)}tbody tr:nth-child(2n){background:#ffffff06}tbody tr:hover{background:#4f8ef712}tbody td{padding:9px 14px;color:var(--text-primary);border-bottom:1px solid rgba(45,49,71,.5);vertical-align:middle}tbody tr:last-child td{border-bottom:none}.spinner{width:48px;height:48px;border:3px solid rgba(79,142,247,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.container{padding:0 var(--spacing-md)}}
