@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--font-sans: "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-primary-50: #eff6ff;--color-primary-100: #dbeafe;--color-primary-500: #2563eb;--color-primary-600: #1d4ed8;--color-primary-700: #1e40af;--color-success-50: #f0fdf4;--color-success-100: #dcfce7;--color-success-500: #22c55e;--color-success-600: #16a34a;--color-success-700: #15803d;--color-warning-50: #fffbeb;--color-warning-100: #fef3c7;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-warning-700: #b45309;--color-danger-50: #fef2f2;--color-danger-100: #fee2e2;--color-danger-500: #ef4444;--color-danger-600: #dc2626;--color-danger-700: #b91c1c;--color-gray-0: #ffffff;--color-gray-50: #f8fafc;--color-gray-100: #f1f5f9;--color-gray-200: #e2e8f0;--color-gray-300: #cbd5e1;--color-gray-400: #94a3b8;--color-gray-500: #64748b;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1e293b;--color-gray-900: #0f172a;--color-sidebar-bg: #0f172a;--color-sidebar-text: #cbd5e1;--color-sidebar-hover: #1e293b;--color-sidebar-active: #1e3a8a;--color-sidebar-active-text: #ffffff;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-base: .2s ease}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;font-family:var(--font-sans);line-height:1.5;font-weight:400;color:var(--color-gray-800);background:linear-gradient(180deg,var(--color-gray-50) 0%,#eef3f8 100%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;color:inherit}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr}.sidebar{background:var(--color-sidebar-bg);color:var(--color-sidebar-text);padding:var(--space-4);display:grid;align-content:start;gap:var(--space-4);position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden}.brand{font-weight:700;letter-spacing:.02em;color:var(--color-gray-0);font-size:1.1rem;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0}.nav-menu{display:grid;gap:var(--space-1)}.nav-link{padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:var(--color-sidebar-text);font-size:.95rem;display:flex;align-items:center;gap:var(--space-3);transition:background var(--transition-fast),color var(--transition-fast)}.nav-link:hover{background:var(--color-sidebar-hover);color:var(--color-gray-0)}.nav-link.active{background:var(--color-sidebar-active);color:var(--color-sidebar-active-text);font-weight:600;box-shadow:var(--shadow-sm)}.nav-section-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-gray-500);padding:var(--space-4) var(--space-3) var(--space-1);font-weight:600}.content-frame{display:grid;grid-template-rows:auto 1fr;min-width:0}.topbar{border-bottom:1px solid var(--color-gray-200);background:var(--color-gray-0);padding:var(--space-3) var(--space-5);display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);position:sticky;top:0;z-index:30}.topbar-title{margin:0;font-weight:600;font-size:1.05rem;color:var(--color-gray-900)}.topbar-subtitle{margin:0;color:var(--color-gray-500);font-size:.85rem}.topbar-actions{display:flex;align-items:center;gap:var(--space-3)}.tenant-selector{display:grid;gap:var(--space-1);font-size:.8rem}.tenant-selector select{border:1px solid var(--color-gray-300);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);min-width:180px;background:var(--color-gray-0);color:var(--color-gray-800)}.tenant-pill{font-size:.85rem;color:var(--color-gray-700);background:var(--color-primary-50);border:1px solid var(--color-primary-100);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-weight:500}.tenant-warning{margin:var(--space-3) var(--space-5) 0;background:var(--color-warning-50);border:1px solid var(--color-warning-100);color:var(--color-warning-700);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--space-3);font-size:.95rem}.content-area{padding:var(--space-5);min-width:0}.page-header{margin-bottom:var(--space-5)}.page-header h1{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-gray-900)}.page-header p{margin:var(--space-2) 0 0;color:var(--color-gray-500);font-size:.95rem}.page-header-actions{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-4)}.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:.85rem;color:var(--color-gray-500);margin-bottom:var(--space-3);flex-wrap:wrap}.breadcrumb a:hover{color:var(--color-primary-600);text-decoration:underline}.breadcrumb-separator{color:var(--color-gray-400)}.breadcrumb-current{color:var(--color-gray-800);font-weight:500}.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-4)}.status-card{background:var(--color-gray-0);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast)}.status-card:hover{box-shadow:var(--shadow-md)}.status-label{margin:0;color:var(--color-gray-500);font-size:.9rem}.status-value{margin:var(--space-2) 0 0;font-size:1.5rem;font-weight:700;color:var(--color-gray-900)}.panel,.module-placeholder{margin-top:var(--space-4);background:var(--color-gray-0);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.module-placeholder h2{margin-top:0}.module-preview pre{margin:var(--space-3) 0 0;overflow:auto;background:var(--color-gray-50);border:1px solid var(--color-gray-200);padding:var(--space-3);border-radius:var(--radius-md);max-height:280px;font-size:.85rem}.meta-text{margin:var(--space-3) 0;color:var(--color-gray-500);font-size:.92rem}.context-pill{margin:0;display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);color:var(--color-primary-700);font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;padding:var(--space-2) var(--space-4);font-size:.95rem;font-weight:500;line-height:1.25;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);white-space:nowrap}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--color-primary-100)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary-600);color:var(--color-gray-0);border-color:var(--color-primary-600)}.btn-primary:hover:not(:disabled){background:var(--color-primary-700);border-color:var(--color-primary-700)}.btn-secondary{background:var(--color-gray-100);color:var(--color-gray-700);border-color:var(--color-gray-200)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-200);border-color:var(--color-gray-300)}.btn-danger{background:var(--color-danger-600);color:var(--color-gray-0);border-color:var(--color-danger-600)}.btn-danger:hover:not(:disabled){background:var(--color-danger-700);border-color:var(--color-danger-700)}.btn-ghost{background:transparent;color:var(--color-gray-600);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--color-gray-100);color:var(--color-gray-800)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:.85rem}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md)}.btn-icon-sm{padding:var(--space-1);border-radius:var(--radius-sm)}.button-primary,.button-secondary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;padding:var(--space-2) var(--space-4);font-size:.95rem;font-weight:500;line-height:1.25;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);white-space:nowrap}.button-primary:focus-visible,.button-secondary:focus-visible{outline:none;box-shadow:0 0 0 3px var(--color-primary-100)}.button-primary:disabled,.button-secondary:disabled{opacity:.6;cursor:not-allowed}.button-primary{background:var(--color-primary-600);color:var(--color-gray-0);border-color:var(--color-primary-600)}.button-primary:hover:not(:disabled){background:var(--color-primary-700);border-color:var(--color-primary-700)}.button-secondary{background:var(--color-gray-100);color:var(--color-gray-700);border-color:var(--color-gray-200)}.button-secondary:hover:not(:disabled){background:var(--color-gray-200);border-color:var(--color-gray-300)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-4);align-items:start}.form-field{display:grid;gap:var(--space-2);font-size:.95rem}.form-field label{font-weight:500;color:var(--color-gray-700);font-size:.9rem}.form-field .required:after{content:" *";color:var(--color-danger-500)}.form-field input,.form-field select,.form-field textarea{border:1px solid var(--color-gray-300);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);background:var(--color-gray-0);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%;box-sizing:border-box;min-height:2.5rem}.form-field textarea{min-height:100px;resize:vertical}.form-field input[type=checkbox],.form-field input[type=radio]{width:auto;padding:0;border:none;margin-right:.5rem;vertical-align:middle}.form-field input[type=file]{padding:.35rem 0;border:none;background:transparent}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.form-field.has-error input,.form-field.has-error select,.form-field.has-error textarea{border-color:var(--color-danger-500);box-shadow:0 0 0 3px var(--color-danger-100)}.form-field .field-error{color:var(--color-danger-600);font-size:.85rem;display:flex;align-items:center;gap:var(--space-1)}.form-field .field-hint{color:var(--color-gray-500);font-size:.85rem}.checkbox-field{display:flex;align-items:center;gap:var(--space-2);font-size:.95rem}.filters-row label,.form-textarea{display:grid;gap:var(--space-2);font-size:.9rem}.filters-row input,.filters-row select,.form-grid input,.form-grid select,.form-textarea textarea{border:1px solid var(--color-gray-300);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);background:var(--color-gray-0);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.filters-row input:focus,.filters-row select:focus,.form-grid input:focus,.form-grid select:focus,.form-textarea textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.form-textarea textarea{width:100%;min-height:100px;resize:vertical}.data-toolbar,.sites-toolbar{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-4);flex-wrap:wrap;margin-bottom:var(--space-4)}.filters-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3);flex:1;min-width:0}.table-wrapper,.sites-table-wrapper{overflow:auto;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);background:var(--color-gray-0);box-shadow:var(--shadow-sm)}.data-table,.sites-table{width:100%;border-collapse:collapse;min-width:720px}.data-table thead,.sites-table thead{background:var(--color-gray-50);position:sticky;top:0;z-index:10}.data-table th,.data-table td,.sites-table th,.sites-table td{border-bottom:1px solid var(--color-gray-200);padding:var(--space-3) var(--space-3);text-align:left;vertical-align:middle;font-size:.92rem}.data-table th,.sites-table th{font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-gray-500);font-weight:600;white-space:nowrap}.data-table tbody tr,.sites-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover,.sites-table tbody tr:hover{background:var(--color-primary-50)}.data-table tbody tr:last-child td,.sites-table tbody tr:last-child td{border-bottom:none}.row-actions{display:flex;align-items:center;gap:var(--space-1)}.skeleton-row td{padding:var(--space-3)}.skeleton-cell{height:1rem;background:linear-gradient(90deg,var(--color-gray-200) 25%,var(--color-gray-100) 50%,var(--color-gray-200) 75%);background-size:200% 100%;border-radius:var(--radius-sm);animation:skeleton-pulse 1.5s infinite}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.status-pill{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap}.status-draft{color:var(--color-gray-600);background:var(--color-gray-100)}.status-active,.status-compliant{color:var(--color-success-700);background:var(--color-success-100)}.status-closed,.status-warning,.status-expiring{color:var(--color-warning-700);background:var(--color-warning-100)}.status-archived{color:#6b21a8;background:#f3e8ff}.status-danger,.status-non-compliant,.status-expired{color:var(--color-danger-700);background:var(--color-danger-100)}.pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) 0;flex-wrap:wrap}.pagination-info{font-size:.9rem;color:var(--color-gray-500)}.pagination-controls{display:flex;align-items:center;gap:var(--space-1)}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:2.25rem;height:2.25rem;padding:0 var(--space-3);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);background:var(--color-gray-0);color:var(--color-gray-700);font-size:.9rem;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--color-gray-100);border-color:var(--color-gray-300)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn.active{background:var(--color-primary-600);border-color:var(--color-primary-600);color:var(--color-gray-0);font-weight:600}.pagination-select{border:1px solid var(--color-gray-300);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);background:var(--color-gray-0);font-size:.9rem}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;right:0;top:calc(100% + var(--space-1));min-width:180px;background:var(--color-gray-0);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:50;padding:var(--space-1);display:grid;gap:var(--space-1);animation:dropdown-in .12s ease forwards}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:.92rem;color:var(--color-gray-700);cursor:pointer;transition:background var(--transition-fast);border:none;background:transparent;width:100%;text-align:left}.dropdown-item:hover{background:var(--color-gray-100)}.dropdown-item.danger{color:var(--color-danger-600)}.dropdown-item.danger:hover{background:var(--color-danger-50)}.dropdown-divider{height:1px;background:var(--color-gray-200);margin:var(--space-1) 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:100;padding:var(--space-4);animation:overlay-in .15s ease forwards}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-gray-0);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:min(520px,100%);max-height:90vh;overflow:auto;display:grid;gap:0;animation:modal-in .2s ease forwards}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6) var(--space-3);border-bottom:1px solid var(--color-gray-100)}.modal-title{margin:0;font-size:1.15rem;font-weight:700;color:var(--color-gray-900)}.modal-close{background:transparent;border:none;cursor:pointer;color:var(--color-gray-400);padding:var(--space-1);border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--color-gray-100);color:var(--color-gray-700)}.modal-body{padding:var(--space-4) var(--space-6);font-size:.95rem;color:var(--color-gray-600);line-height:1.6}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-3) var(--space-6) var(--space-5);border-top:1px solid var(--color-gray-100)}.toast-container{position:fixed;top:var(--space-5);right:var(--space-5);z-index:110;display:grid;gap:var(--space-3);width:min(380px,calc(100vw - var(--space-5) * 2));pointer-events:none}.toast{pointer-events:auto;background:var(--color-gray-0);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-4);display:flex;align-items:flex-start;gap:var(--space-3);animation:toast-in .25s ease forwards;position:relative;overflow:hidden}.toast.toast-success{border-color:var(--color-success-200)}.toast.toast-error{border-color:var(--color-danger-200)}.toast.toast-warning{border-color:var(--color-warning-200)}.toast.toast-info{border-color:var(--color-primary-200)}@keyframes toast-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-exit{animation:toast-out .2s ease forwards}@keyframes toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.toast-icon{flex-shrink:0;margin-top:2px}.toast-content{flex:1;min-width:0}.toast-title{margin:0;font-weight:600;font-size:.95rem;color:var(--color-gray-900)}.toast-message{margin:var(--space-1) 0 0;font-size:.9rem;color:var(--color-gray-600)}.toast-close{background:transparent;border:none;cursor:pointer;color:var(--color-gray-400);padding:var(--space-1);border-radius:var(--radius-sm);display:inline-flex}.toast-close:hover{background:var(--color-gray-100);color:var(--color-gray-700)}.toast-progress{position:absolute;bottom:0;left:0;height:3px;background:var(--color-primary-500);animation:toast-progress 4s linear forwards}.toast-success .toast-progress{background:var(--color-success-500)}.toast-error .toast-progress{background:var(--color-danger-500)}.toast-warning .toast-progress{background:var(--color-warning-500)}.toast-info .toast-progress{background:var(--color-primary-500)}@keyframes toast-progress{0%{width:100%}to{width:0%}}.empty-state{display:grid;place-items:center;text-align:center;padding:var(--space-12) var(--space-5);gap:var(--space-4)}.empty-state-icon{color:var(--color-gray-300)}.empty-state h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--color-gray-700)}.empty-state p{margin:0;color:var(--color-gray-500);font-size:.95rem;max-width:400px}.loading-state{display:grid;place-items:center;text-align:center;padding:var(--space-12) var(--space-5);gap:var(--space-4);color:var(--color-gray-500)}.spinner{width:2rem;height:2rem;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary-600);border-radius:var(--radius-full);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.avatar{width:2.25rem;height:2.25rem;border-radius:var(--radius-full);background:var(--color-primary-600);color:var(--color-gray-0);display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;flex-shrink:0}.user-menu-trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2) var(--space-1) var(--space-1);border-radius:var(--radius-md);border:1px solid var(--color-gray-200);background:var(--color-gray-0);cursor:pointer;transition:background var(--transition-fast)}.user-menu-trigger:hover{background:var(--color-gray-50)}.user-menu-trigger .user-name{font-size:.9rem;font-weight:500;color:var(--color-gray-700)}.screen-center{min-height:100vh;display:grid;place-items:center;padding:var(--space-4)}.login-screen{background:radial-gradient(circle at top,#d7e9ff,#eef4f9 35%,#f5f7fa)}.login-card{width:min(420px,100%);background:var(--color-gray-0);border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);padding:var(--space-6);display:grid;gap:var(--space-4);box-shadow:var(--shadow-lg)}.login-card h1{margin:0;font-size:1.35rem;color:var(--color-gray-900)}.login-card p{margin:0;color:var(--color-gray-500)}.login-card label{display:grid;gap:var(--space-2);font-size:.92rem}.login-card input{border:1px solid var(--color-gray-300);border-radius:var(--radius-md);padding:var(--space-3);background:var(--color-gray-0);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.login-card input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.error-text{color:var(--color-danger-600);margin:0;font-size:.9rem}.success-text{color:var(--color-success-700);margin:var(--space-2) 0;font-size:.9rem}.overview-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);background:linear-gradient(180deg,#f7fbff,#eef4fb);border:1px solid #d5e1ee;border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-4)}.overview-hero-main{display:grid;gap:var(--space-1)}.overview-hero-status{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.overview-critical{margin-bottom:var(--space-4);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);background:var(--color-gray-50);padding:var(--space-4)}.overview-critical h3{margin-top:0;margin-bottom:var(--space-3)}.overview-critical-list{list-style:none;margin:0;padding:0;display:grid;gap:var(--space-3)}.overview-critical-item{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);background:var(--color-gray-0);padding:var(--space-3) var(--space-4)}.overview-critical-main{display:flex;align-items:center;gap:var(--space-2);min-width:0}.overview-critical-side{display:flex;align-items:center;gap:var(--space-2)}.overview-marker{width:.6rem;height:.6rem;border-radius:var(--radius-full);flex-shrink:0}.overview-problem .overview-marker,.overview-marker.overview-problem{background:var(--color-danger-500)}.overview-warning .overview-marker,.overview-marker.overview-warning{background:var(--color-warning-500)}.overview-kpi-secondary .status-card{background:var(--color-gray-50)}.overview-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-4);margin-top:var(--space-4)}.overview-detail-section{border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--space-4);background:var(--color-gray-0)}.overview-detail-section h4{margin:0 0 var(--space-3)}.overview-detail-list{list-style:none;margin:0;padding:0;display:grid;gap:var(--space-2)}.overview-detail-list li{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-2);border:1px solid var(--color-gray-100);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);background:var(--color-gray-50)}.site-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4)}.site-detail-header-status{display:grid;gap:var(--space-1);justify-items:end}.site-detail-nav{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-4)}.site-detail-tab{border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);background:var(--color-gray-50);color:var(--color-gray-700);font-size:.9rem;font-weight:500;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.site-detail-tab:hover{background:var(--color-gray-100)}.site-detail-tab.active{background:var(--color-primary-600);border-color:var(--color-primary-600);color:var(--color-gray-0)}.slide-over-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;justify-content:flex-end;animation:fadeIn .2s ease}.slide-over{background:var(--color-gray-0);height:100%;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);animation:slideInRight .25s ease}.slide-over-size-sm{width:380px;max-width:100vw}.slide-over-size-md{width:520px;max-width:100vw}.slide-over-size-lg{width:720px;max-width:100vw}.slide-over-size-xl{width:960px;max-width:100vw}.slide-over-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-gray-200)}.slide-over-title{margin:0;font-size:1.15rem;font-weight:700;color:var(--color-gray-900)}.slide-over-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--color-gray-500);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.slide-over-close:hover{background:var(--color-gray-100);color:var(--color-gray-800)}.slide-over-body{flex:1;overflow-y:auto;padding:var(--space-6)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.panel-collapsible{margin-top:var(--space-4)}.panel-collapsible-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.panel-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 6px;border-radius:var(--radius-full);background:var(--color-primary-100);color:var(--color-primary-700);font-size:.8rem;font-weight:700}.inline-add-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-3);background:var(--color-gray-50);border:1px dashed var(--color-gray-300);border-radius:var(--radius-md)}.inline-add-row select{min-width:200px}.badge-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:var(--radius-full);background:var(--color-danger-100);color:var(--color-danger-700);font-size:.8rem;font-weight:700}.select-inline{font-size:.9rem;padding:.35rem .5rem;border-radius:var(--radius-md);border:1px solid var(--color-gray-200);background:var(--color-gray-0)}.drawer-entity-detail{display:grid;gap:var(--space-2)}.drawer-entity-detail .meta-text{margin:0}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable-header:hover{background:var(--color-gray-100)}.header-content{display:inline-flex;align-items:center;gap:var(--space-1)}.sort-icon{color:var(--color-gray-400);opacity:.6}.sort-icon.active{color:var(--color-primary-600);opacity:1}.search-bar{display:flex;align-items:center;gap:var(--space-2);max-width:320px;width:100%}.search-bar input{width:100%}.filters-toggle{display:inline-flex;align-items:center;gap:var(--space-2)}.filters-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);background:var(--color-primary-600);color:var(--color-gray-0);font-size:.7rem;font-weight:700}.compliance-badge-btn{background:transparent;border:none;padding:0;cursor:pointer;display:inline-flex;align-items:center}.compliance-badge-btn:disabled{cursor:default}.compliance-row-details{display:grid;gap:var(--space-3);padding:var(--space-3) 0}.compliance-detail-group{display:grid;gap:var(--space-2)}.compliance-detail-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.compliance-detail-list{list-style:none;margin:0;padding:0;display:grid;gap:var(--space-2)}.compliance-detail-list li{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2)}.data-row-expanded{background:var(--color-gray-50)}.data-row-expanded>td{padding:var(--space-3) var(--space-4);border-top:1px dashed var(--color-gray-200)}.alert-banner{display:grid;gap:var(--space-3)}.alert-banner--ok{display:flex;align-items:center;gap:var(--space-3);background:var(--color-success-50);border-color:var(--color-success-200)}.alert-list{list-style:none;margin:0;padding:0;display:grid;gap:var(--space-2)}.alert-list li{display:flex;align-items:center;gap:var(--space-2);font-size:.95rem}.alert-list a{color:var(--color-gray-800);text-decoration:underline;text-underline-offset:3px}.alert-list a:hover{color:var(--color-primary-600)}.compliance-progress-list{display:grid;gap:var(--space-5)}.compliance-progress-item{display:grid;gap:var(--space-2)}.compliance-progress-header{display:flex;justify-content:space-between;align-items:center}.compliance-progress-title{font-weight:600;color:var(--color-gray-800)}.compliance-progress-total{font-size:.85rem;color:var(--color-gray-500)}.compliance-progress-track{display:flex;height:10px;border-radius:var(--radius-full);overflow:hidden;background:var(--color-gray-100)}.compliance-progress-segment{height:100%;transition:width .6s ease}.compliance-progress--compliant{background:var(--color-success-500)}.compliance-progress--expiring{background:var(--color-warning-500)}.compliance-progress--noncompliant{background:var(--color-danger-500)}.compliance-progress--empty{background:var(--color-gray-200)}.compliance-progress-legend{display:flex;flex-wrap:wrap;gap:var(--space-3);font-size:.85rem;color:var(--color-gray-600)}.dot{display:inline-block;width:8px;height:8px;border-radius:var(--radius-full);margin-right:4px}.dot--compliant{background:var(--color-success-500)}.dot--expiring{background:var(--color-warning-500)}.dot--noncompliant{background:var(--color-danger-500)}.quick-sites-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.quick-site-card{display:grid;gap:var(--space-1);padding:var(--space-4);background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);text-decoration:none;color:inherit;transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.quick-site-card:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-md)}.quick-site-name{font-weight:700;color:var(--color-gray-900)}.quick-site-code{font-size:.85rem;color:var(--color-gray-500)}@media (max-width: 920px){.app-shell{grid-template-columns:1fr;grid-template-rows:auto 1fr}.sidebar{position:static;height:auto;padding:var(--space-3)}.brand{justify-content:center}.nav-menu{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.nav-section-title{grid-column:1 / -1}.topbar{flex-direction:column;align-items:flex-start}.tenant-selector select{min-width:0;width:100%}.data-toolbar,.sites-toolbar{align-items:stretch;flex-direction:column}.site-detail-header{flex-direction:column}.site-detail-header-status{justify-items:start}.pagination{flex-direction:column;align-items:stretch}.toast-container{left:var(--space-4);right:var(--space-4);width:auto}}:root{--font-sans: "Inter", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, Roboto, "Helvetica Neue", Arial, sans-serif;--color-primary-50: #edf2ff;--color-primary-100: #dfe7ff;--color-primary-500: #4f6dff;--color-primary-600: #3d58ea;--color-primary-700: #2e46c4;--color-gray-0: #ffffff;--color-gray-50: #f4f7fc;--color-gray-100: #e9eff8;--color-gray-200: #d8e2f1;--color-gray-300: #becce0;--color-gray-400: #8393ad;--color-gray-500: #5a6a85;--color-gray-600: #42516a;--color-gray-700: #2d3a50;--color-gray-800: #1b2638;--color-gray-900: #111a2b;--color-sidebar-bg: linear-gradient(180deg, #10182d 0%, #0e1424 60%, #0a111e 100%);--color-sidebar-text: #b9c7df;--color-sidebar-hover: rgba(104, 137, 255, .14);--color-sidebar-active: linear-gradient(135deg, #4f6dff 0%, #4f89ff 100%);--color-sidebar-active-text: #ffffff;--gradient-primary: linear-gradient(135deg, #4f6dff 0%, #4f89ff 52%, #5da2ff 100%);--gradient-page: radial-gradient(1200px 600px at -12% -10%, #d5e3ff 0%, transparent 52%), radial-gradient(900px 500px at 108% 5%, #dff1ff 0%, transparent 55%), linear-gradient(180deg, #f5f8fd 0%, #ecf2fb 100%);--shadow-soft: 0 8px 24px rgb(22 36 66 / .08);--shadow-md: 0 14px 28px rgb(20 32 57 / .12);--shadow-lg: 0 18px 40px rgb(12 22 43 / .16);--shadow-xl: 0 30px 60px rgb(10 18 36 / .2)}body{color:var(--color-gray-800);background:var(--gradient-page)}.shadow-soft{box-shadow:var(--shadow-soft)}.shadow-lg{box-shadow:var(--shadow-lg)}.radius-md{border-radius:var(--radius-md)}.radius-lg{border-radius:var(--radius-lg)}.app-shell{background:transparent}.sidebar{background:var(--color-sidebar-bg);border-right:1px solid rgb(255 255 255 / .08);box-shadow:inset -1px 0 #ffffff08,var(--shadow-lg)}.brand{padding:.625rem .75rem;border-radius:12px;background:#ffffff0f;border:1px solid rgb(255 255 255 / .08)}.nav-link{transition:background var(--transition-base),color var(--transition-base),transform var(--transition-fast),box-shadow var(--transition-fast)}.nav-link-icon{width:1.25rem;height:1.25rem;display:inline-flex;align-items:center;justify-content:center}.nav-link:hover{transform:translateY(-1px);box-shadow:0 10px 20px #080c1b3d}.nav-link.active{background:var(--color-sidebar-active);box-shadow:0 12px 22px #3e5aeb66}.topbar{border-bottom:1px solid rgb(173 190 220 / .5);background:#ffffffbf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-soft)}.content-area{padding-top:1.4rem}.page-header h1{font-weight:800;letter-spacing:-.01em}.page-header-main{display:grid;gap:.2rem}.panel,.module-placeholder,.status-card{border-color:#b0c1dd80;box-shadow:var(--shadow-soft)}.btn,.button-primary,.button-secondary{border-radius:12px;padding:.64rem 1.1rem;font-weight:600;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-base),border-color var(--transition-base),color var(--transition-base)}.btn:hover:not(:disabled),.button-primary:hover:not(:disabled),.button-secondary:hover:not(:disabled){transform:translateY(-1px)}.btn-primary,.button-primary{background:var(--gradient-primary);border-color:transparent;color:#fff;box-shadow:0 12px 24px #3d58ea47}.btn-primary:hover:not(:disabled),.button-primary:hover:not(:disabled){filter:brightness(1.03);box-shadow:0 16px 30px #3d58ea57}.btn-secondary,.button-secondary{background:#fff;border-color:#adbedce6;color:var(--color-gray-700)}.btn-secondary:hover:not(:disabled),.button-secondary:hover:not(:disabled){background:#f3f7ff;border-color:#8ea4cbf2}.btn-ghost:hover:not(:disabled){background:#eef3ff}.form-field input,.form-field select,.form-field textarea,.filters-row input,.filters-row select,.form-grid input,.form-grid select,.form-textarea textarea,.tenant-selector select,.pagination-select,.login-card input{border:1px solid rgb(171 188 217 / .85);border-radius:10px;padding:.68rem .84rem;background:#fbfdff}.form-field input:focus,.form-field select:focus,.form-field textarea:focus,.filters-row input:focus,.filters-row select:focus,.form-grid input:focus,.form-grid select:focus,.form-textarea textarea:focus,.tenant-selector select:focus,.pagination-select:focus,.login-card input:focus{border-color:#7b96ff;box-shadow:0 0 0 4px #6a85ff38}.table-wrapper,.sites-table-wrapper{border-color:#adbedc99;box-shadow:var(--shadow-soft)}.data-table th,.data-table td,.sites-table th,.sites-table td{padding:.9rem .95rem}.data-table tbody tr,.sites-table tbody tr{transition:background var(--transition-fast),transform var(--transition-fast)}.data-table tbody tr:hover,.sites-table tbody tr:hover{background:linear-gradient(90deg,#f5f8ff,#eef4ff)}.data-table tbody tr:hover td,.sites-table tbody tr:hover td{color:var(--color-gray-900)}.data-actions-cell{white-space:nowrap}.pagination-btn{border-color:#adbedcbf}.pagination-btn.active{background:var(--gradient-primary);border-color:transparent;box-shadow:0 8px 16px #3d58ea47}.dropdown-menu,.modal,.toast,.login-card{border-color:#adbedc99}.empty-state,.loading-state{border:1px solid rgb(173 190 220 / .5);border-radius:18px;background:#ffffffa8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:var(--shadow-soft)}.breadcrumb-item{display:inline-flex;align-items:center;gap:.5rem}.pagination-layout{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.pagination-ellipsis{padding:0 .25rem;color:var(--color-gray-400)}.error-icon{color:var(--color-danger-500)}.modal-size-sm{width:min(380px,100%)}.modal-size-md{width:min(520px,100%)}.modal-size-lg{width:min(720px,100%)}.modal-size-xl{width:min(960px,100%)}.modal-message{margin:0}@media (max-width: 920px){.sidebar{border-right:none;border-bottom:1px solid rgb(255 255 255 / .08)}.topbar{border-radius:0 0 16px 16px}}
