:root{--primary: #0047B3;--primary-dark: #003585;--primary-light: #E8F0FF;--accent: #00B4D8;--accent-light: #E0F7FB;--dark: #1B2B4B;--navy-deep: #07142B;--navy-mid: #102B58;--navy-soft: #0A1D3D;--surface: #F4F7FF;--border: #D1DCF0;--text: #1B2B4B;--text-muted: #5E729A;--white: #FFFFFF;--danger: #DC2626;--success: #16A34A;--warning: #D97706;--radius: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(27,43,75,.08);--shadow-md: 0 4px 16px rgba(27,43,75,.12);--shadow-lg: 0 16px 48px rgba(27,43,75,.18)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--surface);color:var(--text);min-height:100vh;font-size:15px;line-height:1.5}a{color:var(--primary)}.login-container{min-height:100vh;display:grid;grid-template-columns:58% 42%;background:var(--white)}@media (max-width: 880px){.login-container{grid-template-columns:1fr}.login-brand-panel{display:none}}.login-brand-panel{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;padding:4rem 4.5rem;color:var(--white);background:linear-gradient(135deg,var(--navy-deep) 0%,var(--navy-mid) 45%,var(--navy-soft) 100%)}.login-brand-panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 18% 20%,rgba(0,180,216,.18) 0%,transparent 38%),radial-gradient(circle at 85% 82%,rgba(0,180,216,.12) 0%,transparent 42%),repeating-linear-gradient(115deg,rgba(255,255,255,.035) 0 1px,transparent 1px 86px);pointer-events:none}.login-brand-content{position:relative;max-width:480px}.login-brand-mark{display:flex;align-items:center;gap:.85rem;margin-bottom:3rem;font-size:1.35rem;font-weight:800;letter-spacing:.04em;color:var(--white)}.login-brand-icon{height:46px;width:46px;object-fit:contain;border-radius:12px}.login-brand-mark small{display:block;font-size:.7rem;font-weight:500;letter-spacing:.06em;color:#ffffff8c}.login-brand-content h1{font-size:2.6rem;font-weight:800;line-height:1.15;letter-spacing:-.01em;margin-bottom:1rem}.login-brand-content p{font-size:1.05rem;color:#ffffffb8;line-height:1.6;max-width:420px}.login-brand-icons{position:relative;display:flex;gap:.9rem;margin-top:3rem}.login-brand-icons span{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);font-size:1.15rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.login-form-panel{display:flex;align-items:center;justify-content:center;padding:2.5rem}.login-card{background:var(--white);border-radius:26px;padding:3rem 2.75rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid var(--border)}.login-logo{display:block;height:48px;object-fit:contain;margin:0 auto 1.5rem}.login-card h2{text-align:center;font-size:1.5rem;font-weight:800;letter-spacing:-.01em;margin-bottom:.4rem}.login-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:.9rem;text-align:center;line-height:1.5}.login-footer{margin-top:2rem;text-align:center;font-size:.78rem;color:var(--text-muted);letter-spacing:.02em}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.1rem}.field label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.field input,.field textarea,.field select{padding:.6rem .875rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.95rem;width:100%;outline:none;transition:border-color .15s,box-shadow .15s;background:var(--white);color:var(--text);font-family:inherit}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0047b31f}.password-wrapper{position:relative}.password-wrapper input{padding-right:2.8rem}.toggle-password{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;padding:0;color:var(--text-muted)}.field-error{color:var(--danger);font-size:.78rem;margin-top:.2rem}.field-hint{color:var(--text-muted);font-size:.78rem;margin-top:.2rem}.btn-primary{width:100%;padding:.7rem 1.25rem;background:var(--primary);color:var(--white);border:none;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;letter-spacing:.02em}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{padding:.55rem 1.1rem;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--text);font-size:.875rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s}.btn-secondary:hover{border-color:var(--primary);background:var(--primary-light)}.btn-icon{background:none;border:none;cursor:pointer;font-size:1rem;padding:.2rem}.link-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-size:inherit;text-decoration:underline;padding:0}.text-link{color:var(--primary);font-size:.875rem;text-decoration:none}.text-link:hover{text-decoration:underline}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,var(--navy-deep) 0%,var(--navy-mid) 45%,var(--navy-soft) 100%);color:var(--white);padding:0 1.75rem;height:76px;display:flex;align-items:center;gap:2.5rem;flex-shrink:0;box-shadow:0 8px 24px #07142b59;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}.app-wordmark{font-size:1.2rem;font-weight:800;letter-spacing:.06em;color:var(--white)}.app-nav{display:flex;gap:.4rem;flex:1}.app-nav a{position:relative;color:#ffffff9e;text-decoration:none;padding:.5rem 1.1rem;border-radius:999px;font-size:.9rem;font-weight:500;transition:background .2s,color .2s,box-shadow .2s}.app-nav a:hover{color:var(--white);background:#ffffff12}.app-nav a.active{color:var(--white);background:#00b4d829;box-shadow:inset 0 0 0 1px #00b4d866,0 0 18px #00b4d840;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.app-content{flex:1;padding:1.5rem;max-width:1280px;width:100%;margin:0 auto}.header-user{display:flex;align-items:center;gap:1rem;font-size:.875rem;color:#ffffffbf}.btn-logout{background:transparent;border:1px solid rgba(255,255,255,.3);color:#ffffffd9;padding:.3rem .85rem;border-radius:var(--radius);cursor:pointer;font-size:.8rem;transition:background .15s}.btn-logout:hover{background:#ffffff1a}.impersonation-banner{position:sticky;top:0;z-index:1000;background:#92400e;color:var(--white);padding:.55rem 1.5rem;display:flex;align-items:center;justify-content:space-between;font-size:.875rem;font-weight:500}.btn-stop-impersonation{background:#fff3;border:1px solid rgba(255,255,255,.4);color:var(--white);padding:.25rem .85rem;border-radius:var(--radius);cursor:pointer;font-size:.8rem;margin-left:1rem;white-space:nowrap}.btn-stop-impersonation:hover{background:#ffffff4d}.page{display:flex;flex-direction:column;gap:1.25rem}.page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.page-header h2{font-size:1.4rem;font-weight:700;margin:0;color:var(--dark)}.page-actions{display:flex;gap:.75rem}.breadcrumb{font-size:.9rem;color:var(--text-muted)}.breadcrumb span{color:var(--text);font-weight:500}.section-header{display:flex;align-items:center;justify-content:space-between}.section-header h3{margin:0;font-size:1.1rem;color:var(--dark)}.toolbar{display:flex;gap:.75rem}.search-input{padding:.55rem .9rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.9rem;width:320px;outline:none;background:var(--white);transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0047b31a}.table-wrapper{overflow-x:auto;border:1.5px solid var(--border);border-radius:var(--radius-lg);background:var(--white);box-shadow:var(--shadow-sm)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{background:#f0f4ff;padding:.65rem 1rem;text-align:left;font-weight:700;color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1.5px solid var(--border);white-space:nowrap}.data-table td{padding:.65rem 1rem;border-bottom:1px solid #EEF2FF;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#f8faff}.data-table.small th,.data-table.small td{padding:.45rem .75rem;font-size:.8rem}.row-inactive td{opacity:.45}.row-error td{background:#fef2f2!important}.tag{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.tag-manual{background:var(--primary-light);color:var(--primary)}.tag-import{background:#f0fdf4;color:var(--success)}.tag-api{background:#faf5ff;color:#7c3aed}.tag-create{background:#f0fdf4;color:var(--success)}.tag-update{background:var(--primary-light);color:var(--primary)}.tag-automation{background:#fff7ed;color:var(--warning)}.badge{background:var(--border);color:var(--text-muted);border-radius:999px;padding:.1rem .55rem;font-size:.72rem;font-weight:700;margin-left:.4rem}.pagination{display:flex;align-items:center;gap:.75rem;justify-content:center}.pagination button{padding:.35rem .75rem;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--white);cursor:pointer;font-size:.875rem}.pagination button:disabled{opacity:.4;cursor:default}.pagination span{font-size:.875rem;color:var(--text-muted)}.loading,.empty{padding:2.5rem;text-align:center;color:var(--text-muted);font-size:.9rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b2b4b73;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-header{padding:1.25rem 1.5rem;border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h3{margin:0;font-size:1.05rem;font-weight:700;color:var(--dark)}.modal-close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text-muted)}.modal-body{padding:1.25rem 1.5rem;overflow-y:auto;flex:1}.modal-footer{padding:1rem 1.5rem;border-top:1.5px solid var(--border);display:flex;justify-content:flex-end;gap:.75rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem}.form-grid .field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:0}.form-grid .field.col-2{grid-column:span 2}.form-grid input,.form-grid textarea,.form-grid select{padding:.55rem .75rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.875rem;font-family:inherit;outline:none}.form-grid input:focus,.form-grid textarea:focus,.form-grid select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0047b31a}.form-grid label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.detail-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem 2rem}.detail-row{display:flex;flex-direction:column;gap:.15rem;padding:.5rem 0;border-bottom:1px solid #EEF2FF}.detail-row:last-child{border-bottom:none}.detail-label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:.9rem;font-weight:500}.detail-notes{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border)}.tab{padding:.65rem 1.1rem;background:none;border:none;cursor:pointer;font-size:.875rem;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;font-weight:500;transition:color .15s}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:700}.tab:hover:not(.active){color:var(--text)}.machine-list{display:flex;flex-direction:column;gap:.75rem}.machine-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;box-shadow:var(--shadow-sm);transition:border-color .15s}.machine-card:hover{border-color:var(--primary)}.machine-info{flex:1;display:flex;flex-direction:column;gap:.2rem;min-width:180px}.machine-name{font-size:1rem;font-weight:700;text-align:left;color:var(--dark)}.machine-certs{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.machine-actions{display:flex;gap:.5rem;align-items:center}.cert-list{display:flex;flex-direction:column;gap:.75rem}.cert-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;border-left:4px solid var(--border);box-shadow:var(--shadow-sm)}.cert-card.cert-valid{border-left-color:var(--success)}.cert-card.cert-near{border-left-color:var(--warning)}.cert-card.cert-expired{border-left-color:var(--danger)}.cert-card.cert-requested{border-left-color:#7c3aed}.cert-card.cert-scheduled{border-left-color:var(--accent)}.cert-main{flex:1;display:flex;flex-direction:column;gap:.3rem}.cert-type{font-weight:700;font-size:.95rem;color:var(--dark)}.cert-dates{display:flex;gap:1rem;flex-wrap:wrap;font-size:.825rem;color:var(--text-muted)}.cert-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0;flex-wrap:wrap}.cert-actions{display:flex;gap:.5rem;align-items:center}.status-pill{display:inline-block;padding:.2rem .7rem;border-radius:999px;font-size:.75rem;font-weight:700}.cert-valid .status-pill,.status-pill.cert-valid{background:#f0fdf4;color:var(--success)}.cert-near .status-pill,.status-pill.cert-near{background:#fffbeb;color:var(--warning)}.cert-expired .status-pill,.status-pill.cert-expired{background:#fef2f2;color:var(--danger)}.cert-requested.status-pill,.status-pill.cert-requested{background:#faf5ff;color:#7c3aed}.cert-scheduled.status-pill,.status-pill.cert-scheduled{background:var(--accent-light);color:#0369a1}.days-badge{display:inline-block;padding:.15rem .55rem;border-radius:6px;font-size:.75rem;font-weight:700}.days-ok{background:#f0fdf4;color:var(--success)}.days-near{background:#fffbeb;color:var(--warning)}.days-expired{background:#fef2f2;color:var(--danger)}.wizard-steps{display:flex;gap:0;margin-bottom:.5rem}.wizard-step{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;font-size:.875rem;color:var(--text-muted)}.wizard-step.active{color:var(--primary);font-weight:700}.wizard-step.done{color:var(--success)}.step-num{width:24px;height:24px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;color:var(--text-muted)}.wizard-step.active .step-num{background:var(--primary);color:var(--white)}.wizard-step.done .step-num{background:var(--success);color:var(--white)}.wizard-panel{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;box-shadow:var(--shadow-sm)}.wizard-panel h3{margin:0;color:var(--dark)}.wizard-actions{display:flex;justify-content:flex-end;gap:.75rem}.file-input{padding:.5rem;border:1.5px dashed var(--border);border-radius:var(--radius);width:100%;cursor:pointer;background:var(--surface)}.mapping-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem}.mapping-grid .field{display:flex;flex-direction:column;gap:.3rem}.mapping-grid label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.mapping-grid select{padding:.5rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.875rem;outline:none}.mapping-grid select:focus{border-color:var(--primary)}.sample-table-wrapper{overflow:hidden}.summary-chips{display:flex;gap:.75rem;flex-wrap:wrap}.chip{padding:.35rem .9rem;border-radius:999px;font-size:.875rem;font-weight:600}.chip-green{background:#f0fdf4;color:var(--success);border:1px solid #BBF7D0}.chip-blue{background:var(--primary-light);color:var(--primary);border:1px solid #BFDBFE}.chip-red{background:#fef2f2;color:var(--danger);border:1px solid #FECACA}.done-panel{align-items:center;text-align:center;padding:3rem}.done-icon{font-size:3rem}.error-details{margin-top:.75rem;font-size:.875rem}.error-details summary{cursor:pointer;color:var(--danger)}.error-details ul{margin-top:.5rem;padding-left:1.25rem;color:#7f1d1d}.input-addon-wrap{position:relative}.input-addon-wrap input{width:100%;padding-right:2.5rem}.input-addon{position:absolute;right:.65rem;top:50%;transform:translateY(-50%);font-size:1rem;pointer-events:none;line-height:1}.addon-spin{animation:spin .8s linear infinite;display:inline-block;color:var(--text-muted)}@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}.input-valid{border-color:var(--success)!important}.input-error{border-color:var(--danger)!important}.input-valid:focus{box-shadow:0 0 0 3px #16a34a1f!important}.input-error:focus{box-shadow:0 0 0 3px #dc26261f!important}.field-hint-ok{color:var(--success)}.text-muted{color:var(--text-muted);font-size:.875rem}.text-error{color:var(--danger);font-size:.8rem}.success-msg{color:var(--success);font-size:.875rem;margin-bottom:.75rem;background:#f0fdf4;border:1px solid #BBF7D0;padding:.6rem .9rem;border-radius:var(--radius)}.error-msg{color:var(--danger);font-size:.875rem;margin-bottom:.75rem}code{background:#eef2ff;color:var(--primary);padding:.1rem .4rem;border-radius:4px;font-size:.8rem}.btn-sm{padding:.3rem .75rem;font-size:.8rem}.input-readonly{background:var(--surface);color:var(--text-muted);cursor:default}.header-user{position:relative}.profile-trigger{display:flex;align-items:center;gap:.6rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:.3rem .9rem .3rem .3rem;cursor:pointer;color:#ffffffd9;font-size:.85rem;font-family:inherit;transition:background .15s,border-color .15s}.profile-trigger:hover{background:#ffffff1a;border-color:#ffffff38}.profile-name{font-weight:600;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-caret{font-size:.7rem;opacity:.6}.profile-avatar-sm{width:30px;height:30px;border-radius:50%;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent) 0%,var(--primary) 100%);color:var(--white);font-size:.75rem;font-weight:700}.profile-avatar-sm img{width:100%;height:100%;object-fit:cover}.profile-dropdown{position:absolute;top:calc(100% + .6rem);right:0;z-index:250;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:180px;overflow:hidden;padding:.4rem}.profile-dropdown button{display:block;width:100%;text-align:left;padding:.55rem .75rem;border:none;background:none;border-radius:var(--radius);font-size:.875rem;color:var(--text);cursor:pointer;font-family:inherit;transition:background .15s}.profile-dropdown button:hover{background:var(--surface)}.modal-profile{max-width:520px}.profile-tabs{display:flex;gap:.25rem;padding:0 1.5rem;border-bottom:1.5px solid var(--border)}.profile-tabs button{padding:.7rem .9rem;background:none;border:none;cursor:pointer;font-size:.85rem;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;font-weight:600;font-family:inherit;transition:color .15s}.profile-tabs button.active{color:var(--primary);border-bottom-color:var(--primary)}.profile-tabs button:hover:not(.active){color:var(--text)}.profile-avatar-row{display:flex;align-items:center;gap:1.1rem;margin-bottom:1.5rem}.profile-avatar{width:64px;height:64px;border-radius:50%;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent) 0%,var(--primary) 100%);color:var(--white);font-size:1.3rem;font-weight:700}.profile-avatar img{width:100%;height:100%;object-fit:cover}.danger-zone{display:flex;flex-direction:column;gap:.9rem;align-items:flex-start}.btn-danger{padding:.6rem 1.1rem;border:1.5px solid var(--danger);border-radius:var(--radius);background:var(--white);color:var(--danger);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.btn-danger:hover:not(:disabled){background:var(--danger);color:var(--white)}.btn-danger:disabled{opacity:.55;cursor:not-allowed}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-top:1.25rem}.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.4rem;display:flex;flex-direction:column;gap:.4rem}.stat-label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.stat-value{font-size:2rem;font-weight:700;color:var(--text)}.stat-card-total{background:linear-gradient(135deg,var(--accent) 0%,var(--primary) 100%);border:none}.stat-card-total .stat-label,.stat-card-total .stat-value{color:var(--white)}.public-os-page{min-height:100vh;background:#f4f6fb;padding:2rem 1rem}.public-os-header{display:flex;align-items:center;gap:.7rem;justify-content:center;margin-bottom:2rem}.public-os-header .app-wordmark{color:var(--dark);font-size:1.2rem;font-weight:800;letter-spacing:.06em}
