*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:#f5f5f5;color:#333;line-height:1.6}.hidden{display:none!important}.text-muted{color:#6b7280;font-size:.85rem;margin:.25rem 0 0}.text-error{color:#dc2626;font-size:.85rem}.text-success{color:#059669;font-size:.85rem}.btn{display:inline-block;padding:.5rem .85rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;font-weight:500;line-height:1.2;text-align:center;text-decoration:none;cursor:pointer;background:#fff;color:#374151;transition:background-color .15s,border-color .15s,color .15s}.btn:hover{background:#f3f4f6;border-color:#9ca3af}.btn:disabled,.btn[disabled]{cursor:not-allowed;opacity:.6}.btn-primary{background:#2563eb;color:#fff;border-color:#2563eb}.btn-primary:hover{background:#1d4ed8;border-color:#1d4ed8}.btn-primary:disabled,.btn-primary[disabled]{background:#93c5fd;border-color:#93c5fd;opacity:1}.btn-secondary{background:#fff;color:#374151;border-color:#d1d5db}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.btn-danger{background:#dc2626;color:#fff;border-color:#dc2626}.btn-danger:hover{background:#b91c1c;border-color:#b91c1c}.btn-block{display:block;width:100%}.btn-small{padding:.25rem .55rem;font-size:.75rem}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem}.auth-card{background:#fff;border-radius:8px;box-shadow:0 2px 16px #0000001a;padding:2.5rem;width:100%;max-width:400px}.auth-card h1,.auth-title{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.auth-subtitle{color:#666;margin-bottom:1.5rem;font-size:.9rem}.auth-error{background:#fef2f2;color:#dc2626;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem}.auth-info{background:#eff6ff;color:#1e40af;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem}.auth-hint{color:#6b7280;font-size:.85rem;margin-top:1rem}.auth-hint a{color:#2563eb;text-decoration:none}.auth-hint a:hover{text-decoration:underline}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem;color:#374151}.form-group input{width:100%;padding:.5rem .65rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;transition:border-color .15s}.form-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}form .btn-block{margin-top:.5rem}.auth-card .btn-block+.btn-block{margin-top:.75rem}.auth-link{text-align:center;margin-top:1.25rem;font-size:.875rem;color:#666}.auth-link a{color:#2563eb;text-decoration:none;font-weight:500}.auth-link a:hover{text-decoration:underline}.auth-divider{display:flex;align-items:center;margin:1.25rem 0;color:#9ca3af;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid #e5e7eb}.auth-divider span{padding:0 .75rem}.google-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.55rem;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background-color .15s,border-color .15s}.google-btn:hover{background:#f9fafb;border-color:#9ca3af}.google-icon{flex-shrink:0}.admin-card{border-top:3px solid #1e40af}.admin-dashboard .btn-primary,.admin-card .btn-primary{background:#1e40af;border-color:#1e40af}.admin-dashboard .btn-primary:hover,.admin-card .btn-primary:hover{background:#1e3a8a;border-color:#1e3a8a}.admin-dashboard .btn-primary:disabled,.admin-card .btn-primary:disabled{background:#93c5fd;border-color:#93c5fd;opacity:1}.admin-dashboard{min-height:100vh;background:#f5f5f5}.admin-header{display:flex;justify-content:space-between;align-items:center;background:#1e40af;color:#fff;padding:.75rem 1.5rem}.admin-header h1{font-size:1.1rem;font-weight:600}.admin-header-right{display:flex;align-items:center;gap:1rem}.admin-user{font-size:.875rem;opacity:.9}.admin-logout{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;padding:.35rem .75rem;font-size:.8rem;cursor:pointer}.admin-logout:hover{background:#ffffff40}.admin-layout{display:flex;min-height:calc(100vh - 50px)}.admin-sidebar{width:200px;background:#fff;border-right:1px solid #e5e7eb;padding:1rem 0;display:flex;flex-direction:column}.admin-sidebar .nav-link{display:block;padding:.6rem 1.25rem;color:#374151;text-decoration:none;font-size:.875rem;border-left:3px solid transparent}.admin-sidebar .nav-link:hover{background:#f3f4f6}.admin-sidebar .nav-link.active{color:#1e40af;background:#eff6ff;border-left-color:#1e40af;font-weight:500}.admin-content{flex:1;padding:1.5rem 2rem;max-width:1100px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.page-header h2{font-size:1.25rem;font-weight:600;margin:0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.section-header h3{font-size:1rem;font-weight:600;margin:0}.section-header-spaced{margin-top:2rem}.breadcrumb{font-size:.8rem;color:#6b7280;text-decoration:none}.breadcrumb:hover{color:#1e40af}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 1px 3px #00000014}.data-table th{text-align:left;padding:.6rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#6b7280;background:#f9fafb;border-bottom:1px solid #e5e7eb}.data-table td{padding:.6rem .75rem;font-size:.85rem;border-bottom:1px solid #f3f4f6}.data-table tr.clickable{cursor:pointer}.data-table tr.clickable:hover{background:#f9fafb}.data-table-empty{text-align:center;color:#9ca3af;padding:2rem!important}.table-actions{display:flex;gap:.35rem}.tab-nav{display:flex;border-bottom:2px solid #e5e7eb;margin-bottom:1.25rem}.tab{padding:.5rem 1rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-size:.85rem;color:#6b7280}.tab:hover{color:#374151}.tab.active{color:#1e40af;border-bottom-color:#1e40af;font-weight:500}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:8px;padding:1.5rem;min-width:380px;max-width:500px;box-shadow:0 10px 25px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.modal-header h3{margin:0;font-size:1.05rem}.modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:#6b7280;padding:0}.modal .form-group{margin-bottom:.75rem}.modal .form-group label{display:block;font-size:.8rem;font-weight:500;margin-bottom:.25rem}.badge{display:inline-block;padding:.2rem .5rem;border-radius:3px;font-size:.75rem;font-weight:500}.badge-active{background:#dcfce7;color:#166534}.badge-inactive{background:#fee2e2;color:#991b1b}.badge-perm{background:#dbeafe;color:#1e40af;margin:.2rem .25rem}.badge-inherited{background:#f3f4f6;color:#6b7280;margin:.2rem .25rem}.badge-remove{background:none;border:none;cursor:pointer;font-size:.9rem;color:inherit;margin-left:.25rem;padding:0}.permission-list{display:flex;flex-wrap:wrap;gap:.15rem;margin-top:.5rem;margin-bottom:.5rem}.permission-list-inline{margin:0}.action-input-row{display:flex;gap:.5rem}.action-suggestions{margin-top:.5rem;display:flex;gap:.25rem;flex-wrap:wrap}.modal-actions{margin-top:1rem}.permission-picker{display:flex;gap:.35rem;margin-bottom:.5rem}.permission-picker input{flex:1;padding:.35rem .5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.85rem}.permission-picker select{padding:.35rem .5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.85rem}.user-search-form{display:flex;gap:.35rem;margin-bottom:.5rem}.user-search-form input{flex:1;padding:.4rem .5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.85rem}.user-search-result{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#f9fafb;border-radius:4px;font-size:.85rem}.user-search-not-found{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.user-search-not-found p{margin:0}.user-create-form{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.user-create-form .form-actions{display:flex;gap:.5rem;margin-top:.5rem}.form-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.form-section:last-child{border-bottom:none}.form-section h4{font-size:1rem;font-weight:600;color:#374151;margin-bottom:1rem}.form-row{margin-bottom:.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#374151;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;margin:0}.save-row{display:flex;align-items:center;gap:1rem;margin-top:1.5rem}.spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:#6b7280;font-size:.875rem}.spinner{border-radius:50%;border-style:solid;border-color:#e5e7eb;border-top-color:#1e40af;animation:spinner-rotate .8s linear infinite}.spinner-small{width:16px;height:16px;border-width:2px}.spinner-medium{width:32px;height:32px;border-width:3px}.spinner-large{width:48px;height:48px;border-width:4px}.spinner-label{color:#6b7280}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.forbidden-card{max-width:480px;margin:3rem auto;padding:2rem;background:#fff;border:1px solid #fde68a;border-radius:8px;text-align:center;box-shadow:0 1px 3px #0000000d}.forbidden-icon{font-size:2rem;color:#d97706;margin-bottom:.5rem}.forbidden-card h2{font-size:1.15rem;font-weight:600;color:#374151;margin-bottom:.5rem}.forbidden-card p{color:#6b7280;font-size:.9rem;margin-bottom:.5rem}.forbidden-card code{background:#f3f4f6;padding:.1rem .35rem;border-radius:3px;font-size:.8rem;color:#374151}.qr-code-container{display:flex;justify-content:center;padding:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin:1rem 0;max-width:240px}
