.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2rem;border-radius:10px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-box h1{text-align:center;color:#333;margin-bottom:2rem;font-size:2rem}.form-group{margin-bottom:1.5rem}.form-group input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:5px;font-size:1rem;transition:border-color .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.login-button{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:5px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:5px;margin-bottom:1rem;text-align:center;font-size:.9rem}.form-group select{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:5px;font-size:1rem;transition:border-color .3s;box-sizing:border-box;background-color:#fff}.form-group select:focus{outline:none;border-color:#667eea}.invite-form{padding:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500;font-size:.9rem}.form-group input,.form-group select{width:100%;padding:.6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;font-family:inherit}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.modal-actions button{padding:.6rem 1.25rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.modal-actions button[type=button]{background:#f0f0f0;color:#333}.modal-actions button[type=button]:hover{background:#e0e0e0}.modal-actions .btn-primary{background:#667eea;color:#fff}.modal-actions .btn-primary:hover{background:#5568d3}.modal-actions button:disabled{opacity:.6;cursor:not-allowed}.invitations-list{margin-top:1.5rem}.invitations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.invitations-header h3{margin:0;color:#333;font-size:1.1rem}.invitations-table{overflow-x:auto;border:1px solid #e0e0e0;border-radius:6px}.invitations-table table{width:100%;border-collapse:collapse;font-size:.85rem}.invitations-table th{background:#f8f9fa;padding:.6rem .75rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.invitations-table td{padding:.6rem .75rem;border-bottom:1px solid #e0e0e0}.invitations-table tr:last-child td{border-bottom:none}.status-badge.accepted{background:#d4edda;color:#155724}.status-badge.expired{background:#f8d7da;color:#721c24}.btn-delete{padding:.3rem .6rem;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background .2s}.user-management{width:100%;height:100%}.btn-primary{background:#667eea;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:5px;cursor:pointer;font-size:.95rem;font-weight:600}.create-user-form{background:#f8f9fa;padding:1rem;border-radius:6px;margin-bottom:1rem;border:1px solid #e0e0e0}.create-user-form h3{margin-top:0;margin-bottom:1rem;color:#333;font-size:1.1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.form-group label{margin-bottom:.5rem;color:#666;font-size:.9rem;font-weight:500}.form-group input,.form-group select{padding:.75rem;border:2px solid #e0e0e0;border-radius:5px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.users-table{overflow-x:auto;max-height:calc(100vh - 300px);border:1px solid #e0e0e0;border-radius:6px}.users-table table{width:100%;border-collapse:collapse;font-size:.9rem}.users-table th{background:#f8f9fa;padding:.6rem .75rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;position:sticky;top:0;z-index:10}.users-table td{padding:.6rem .75rem;border-bottom:1px solid #e0e0e0}.users-table tr:hover{background:#f8f9fa}.badge{padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500;text-transform:capitalize}.badge-company{background:#e3f2fd;color:#1976d2}.badge-client{background:#f3e5f5;color:#7b1fa2}.roles-list{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.role-tag{background:#667eea;color:#fff;padding:.25rem .5rem .25rem .75rem;border-radius:20px;font-size:.85rem;display:inline-flex;align-items:center;gap:.5rem}.remove-role{background:#ffffff4d;border:none;color:#fff;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;padding:0}.remove-role:hover{background:#ffffff80}.add-role-select{border:1px dashed #667eea;background:#fff;color:#667eea;padding:.25rem .5rem;border-radius:20px;font-size:.85rem;cursor:pointer}.status-toggle{padding:.5rem 1rem;border:none;border-radius:20px;cursor:pointer;font-size:.85rem;font-weight:500}.status-toggle.active{background:#d4edda;color:#155724}.status-toggle.inactive{background:#f8d7da;color:#721c24}.btn-small{background:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:5px;cursor:pointer;font-size:.85rem}.btn-small:hover{background:#5a6268}.loading{text-align:center;padding:3rem;color:#666}.role-management{width:100%;height:100%}.create-role-form{background:#f8f9fa;padding:1rem;border-radius:6px;margin-bottom:1rem;border:1px solid #e0e0e0}.create-role-form h3{margin-top:0;margin-bottom:1rem;color:#333;font-size:1.1rem}.permissions-section{margin-top:1.5rem}.permissions-section h4{margin-bottom:1rem;color:#333}.permission-row{display:flex;align-items:center;padding:.5rem .75rem;background:#fff;border-radius:4px;margin-bottom:.4rem}.resource-label{min-width:120px;font-weight:600;color:#333;text-transform:capitalize}.permission-actions{display:flex;gap:1.5rem}.permission-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer}.permission-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.roles-sections{display:flex;flex-direction:column;gap:1rem;max-height:calc(100vh - 250px);overflow-y:auto}.roles-section h3{color:#333;margin-bottom:.75rem;font-size:1.1rem;position:sticky;top:0;background:#fff;padding:.5rem 0;z-index:5}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1rem}.role-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:1rem}.role-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.role-card-header h4{margin:0 0 .5rem;color:#333}.role-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.role-badge.system{background:#e3f2fd;color:#1976d2}.role-badge.custom{background:#fff3e0;color:#e65100}.role-card-actions{display:flex;gap:.5rem}.btn-danger{background:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:5px;cursor:pointer;font-size:.85rem}.btn-danger:hover{background:#c82333}.role-permissions{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e0e0e0}.role-permissions table{width:100%;border-collapse:collapse;font-size:.85rem}.role-permissions th{background:#fff;padding:.5rem .75rem;text-align:left;font-weight:600;color:#666;font-size:.85rem;border-bottom:1px solid #e0e0e0}.role-permissions td{padding:.5rem .75rem;border-bottom:1px solid #f0f0f0}.role-permissions input[type=checkbox]{width:18px;height:18px;cursor:pointer}.role-permissions input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.permission-matrix{width:100%;height:100%;display:flex;flex-direction:column}.filter-controls{display:flex;align-items:center;gap:.75rem}.filter-controls label{color:#666;font-weight:500;font-size:.9rem}.filter-controls select{padding:.4rem .75rem;border:1px solid #e0e0e0;border-radius:4px;font-size:.9rem}.matrix-container{overflow:auto;flex:1;border:1px solid #e0e0e0;border-radius:6px;margin-top:.5rem}.matrix-table{width:100%;border-collapse:collapse;background:#fff;font-size:.85rem}.matrix-table th{background:#f8f9fa;padding:.6rem .5rem;text-align:center;font-weight:600;color:#333;border:1px solid #e0e0e0;position:sticky;top:0;z-index:10}.role-header{background:#667eea!important;color:#fff!important;text-align:left!important;min-width:150px}.resource-header{background:#e3f2fd!important;color:#1976d2!important;text-transform:capitalize;font-size:.95rem}.action-header{background:#f5f5f5!important;color:#666!important;font-size:.85rem;font-weight:500;min-width:50px}.role-cell{background:#f8f9fa;padding:.6rem .75rem;border:1px solid #e0e0e0;min-width:140px;position:sticky;left:0;z-index:5}.role-name{font-weight:600;color:#333;margin-bottom:.5rem}.role-type-badge{display:inline-block;padding:.25rem .5rem;border-radius:15px;font-size:.75rem;font-weight:500;margin-right:.5rem}.role-type-badge.company{background:#e3f2fd;color:#1976d2}.role-type-badge.client{background:#f3e5f5;color:#7b1fa2}.custom-badge{display:inline-block;padding:.25rem .5rem;border-radius:15px;font-size:.7rem;background:#fff3e0;color:#e65100}.permission-cell{text-align:center;padding:.5rem;border:1px solid #e0e0e0}.permission-indicator{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-weight:700;font-size:.9rem}.permission-indicator.granted{background:#d4edda;color:#155724}.permission-indicator.denied{background:#f8d7da;color:#721c24}.matrix-legend{display:flex;gap:1.5rem;margin-top:.75rem;padding:.75rem;background:#f8f9fa;border-radius:6px;flex-shrink:0}.legend-item{display:flex;align-items:center;gap:.75rem}.legend-item span{color:#666;font-size:.9rem}.users-and-roles{width:100%;height:100%;display:flex;flex-direction:column}.section-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid #e0e0e0;overflow-x:auto}.section-tab{padding:.75rem 1.25rem;border:none;background:transparent;cursor:pointer;border-radius:6px 6px 0 0;font-size:.9rem;color:#666;transition:all .2s;display:flex;align-items:center;gap:.5rem;white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px}.section-tab:hover{background:#f8f9fa;color:#333}.section-tab.active{color:#667eea;border-bottom-color:#667eea;background:transparent;font-weight:600}.section-content{flex:1;overflow-y:auto}.access-denied{text-align:center;padding:3rem;color:#666}.project-access{width:100%;height:100%;display:flex;flex-direction:column}.projects-list{display:flex;flex-direction:column;gap:1rem;flex:1;overflow-y:auto}.project-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:1rem}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.project-card-header h3{margin:0 0 .25rem;color:#333;font-size:1.1rem}.project-description{color:#666;font-size:.9rem;margin:0}.project-actions{display:flex;gap:1rem}.modal-content{background:#fff;padding:1.5rem;border-radius:6px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h3{margin-top:0;color:#333}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.modal-content .form-group{margin-bottom:1rem}.modal-content .form-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.modal-content input[type=checkbox]{width:18px;height:18px;cursor:pointer}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h3{margin:0}.close-btn{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;line-height:1;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#333}.access-details{max-width:900px}.access-table{width:100%;border-collapse:collapse;font-size:.85rem}.access-table th{background:#f8f9fa;padding:.6rem .75rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;font-size:.85rem}.access-table td{padding:.6rem .75rem;border-bottom:1px solid #e0e0e0;font-size:.85rem}.access-type-badge{padding:.25rem .75rem;border-radius:15px;font-size:.75rem;font-weight:500}.access-type-badge.user_override{background:#e3f2fd;color:#1976d2}.access-type-badge.role_default{background:#f3e5f5;color:#7b1fa2}.access-requests-list{margin-top:1.5rem}.requests-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.requests-header h3{margin:0;color:#333;font-size:1.1rem}.filter-tabs{display:flex;gap:.5rem}.filter-tabs button{padding:.4rem .75rem;border:1px solid #e0e0e0;background:#fff;border-radius:4px;cursor:pointer;font-size:.85rem;color:#666;transition:all .2s}.filter-tabs button:hover{background:#f8f9fa;border-color:#667eea}.filter-tabs button.active{background:#667eea;color:#fff;border-color:#667eea}.requests-table{overflow-x:auto;border:1px solid #e0e0e0;border-radius:6px}.requests-table table{width:100%;border-collapse:collapse;font-size:.85rem}.requests-table th{background:#f8f9fa;padding:.6rem .75rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.requests-table td{padding:.6rem .75rem;border-bottom:1px solid #e0e0e0}.requests-table tr:last-child td{border-bottom:none}.user-type-badge{background:#e3f2fd;color:#1976d2;padding:.2rem .5rem;border-radius:3px;font-size:.75rem;text-transform:capitalize;font-weight:500}.status-badge{padding:.25rem .5rem;border-radius:3px;font-size:.75rem;font-weight:500}.status-badge.pending{background:#fff3cd;color:#856404}.status-badge.approved{background:#d4edda;color:#155724}.status-badge.denied{background:#f8d7da;color:#721c24}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.btn-approve,.btn-deny,.btn-delete{padding:.3rem .6rem;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background .2s}.btn-approve{background:#28a745;color:#fff}.btn-approve:hover{background:#218838}.btn-deny{background:#ffc107;color:#333}.btn-deny:hover{background:#e0a800}.btn-delete{background:#dc3545;color:#fff}.btn-delete:hover{background:#c82333}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;color:#333;font-size:1.25rem}.modal-close{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.modal-close:hover{background:#f0f0f0}.modal-body{padding:1.5rem}.modal-body p{margin:.5rem 0;color:#333}.modal-body .form-group{margin-top:1rem}.modal-body textarea{width:100%;padding:.6rem;border:1px solid #ddd;border-radius:4px;font-family:inherit;resize:vertical}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e0e0e0}.modal-actions button{padding:.6rem 1.25rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500}.modal-actions button:first-child{background:#f0f0f0;color:#333}.modal-actions button:first-child:hover{background:#e0e0e0}.empty-state,.loading{text-align:center;padding:2rem;color:#666}.setup-container{width:100%;height:100%;display:flex;flex-direction:column}.setup-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.setup-header h1{margin:0 0 .5rem;color:#333;font-size:1.5rem;font-weight:600}.setup-description{margin:0;color:#666;font-size:.9rem}.setup-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid #e0e0e0;overflow-x:auto}.setup-tab{padding:.75rem 1.25rem;border:none;background:transparent;cursor:pointer;border-radius:6px 6px 0 0;font-size:.9rem;color:#666;transition:all .2s;display:flex;align-items:center;gap:.5rem;white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px}.setup-tab:hover{background:#f8f9fa;color:#333}.setup-tab.active{color:#667eea;border-bottom-color:#667eea;background:transparent;font-weight:600}.tab-icon{font-size:1rem}.tab-label{font-weight:inherit}.setup-content{flex:1;overflow-y:auto}.setup-general{max-width:800px}.setup-general h2{margin:0 0 1.5rem;color:#333;font-size:1.25rem}.settings-section{margin-bottom:2rem;padding:1.5rem;background:#f8f9fa;border-radius:6px;border:1px solid #e0e0e0}.settings-section h3{margin:0 0 1rem;color:#333;font-size:1.1rem}.settings-section p{margin:0;color:#666;font-size:.9rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item label{font-size:.85rem;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.info-item span{font-size:.95rem;color:#333;font-weight:500}.main-dashboard{min-height:100vh;background:#f5f5f5;display:flex;flex-direction:column}.dashboard-header{background:#fff;padding:.75rem 1.5rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;z-index:100}.header-left{display:flex;align-items:center;gap:.75rem}.logo{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem}.dashboard-header h1{margin:0;color:#333;font-size:1.25rem;font-weight:600}.header-right{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.5rem;color:#333;font-size:.9rem;font-weight:500}.user-role{background:#e3f2fd;color:#1976d2;padding:.2rem .5rem;border-radius:3px;font-size:.75rem;text-transform:lowercase;font-weight:500}.header-actions{display:flex;align-items:center;gap:.5rem}.icon-btn{width:36px;height:36px;border:none;background:transparent;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:background .2s}.icon-btn:hover{background:#f0f0f0}.logout-btn:hover{background:#ffebee}.dashboard-container{display:flex;flex:1;overflow:hidden}.sidebar{width:220px;background:#f8f9fa;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;transition:width .3s ease}.sidebar.collapsed{width:60px}.sidebar-header{padding:1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e0e0;background:#fff}.sidebar-title{font-weight:600;color:#333;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.sidebar.collapsed .sidebar-title{display:none}.sidebar-toggle{padding:.4rem;border:none;background:transparent;cursor:pointer;border-radius:4px;font-size:1rem;color:#666;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:background .2s}.sidebar-toggle:hover{background:#f0f0f0}.sidebar.collapsed .sidebar-header{justify-content:center;padding:1rem .5rem}.sidebar-menu{flex:1;overflow-y:auto;padding:.5rem;display:flex;flex-direction:column;gap:.25rem}.menu-item{padding:.75rem 1rem;border:none;background:transparent;text-align:left;cursor:pointer;border-radius:6px;font-size:.9rem;color:#555;transition:all .2s;display:flex;align-items:center;gap:.75rem;white-space:nowrap;overflow:hidden;width:100%}.sidebar.collapsed .menu-item{justify-content:center;padding:.75rem}.menu-icon{font-size:1.1rem;flex-shrink:0;width:20px;text-align:center}.menu-label{flex:1}.sidebar.collapsed .menu-label{display:none}.menu-item:hover{background:#e9ecef;color:#333}.menu-item.active{background:#667eea;color:#fff;font-weight:500}.menu-item.active:hover{background:#5568d3}.dashboard-content{flex:1;background:#fff;padding:1rem 1.5rem;overflow-y:auto}.projects-view{width:100%;height:100%}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e0e0e0}.page-header h2{margin:0;color:#333;font-size:1.25rem}.btn-primary{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:600}.empty-state{text-align:center;padding:3rem;color:#666}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.project-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:1rem;transition:all .2s}.project-card:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.project-card h3{margin:0 0 .5rem;color:#333;font-size:1.1rem}.project-card p{margin:0 0 1rem;color:#666;font-size:.9rem}.project-actions{display:flex;gap:.5rem}.project-actions button{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.project-actions button:hover{background:#5568d3}.loading{display:flex;justify-content:center;align-items:center;padding:2rem;color:#666}.accept-invitation-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.accept-invitation-box{background:#fff;border-radius:8px;padding:2.5rem;width:100%;max-width:500px;box-shadow:0 4px 20px #0003}.invitation-header{text-align:center;margin-bottom:2rem}.invitation-header h1{margin:0 0 .5rem;color:#333;font-size:1.75rem}.invitation-header p{margin:0;color:#666;font-size:.95rem}.invitation-info{background:#f8f9fa;padding:1rem;border-radius:6px;margin-bottom:1.5rem;border-left:4px solid #667eea}.invitation-info p{margin:.5rem 0;color:#333;font-size:.9rem}.accept-form{display:flex;flex-direction:column;gap:1rem}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;font-family:inherit}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.loading{text-align:center;padding:2rem;color:#666}.request-access-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.request-access-box{background:#fff;border-radius:8px;padding:2.5rem;width:100%;max-width:600px;box-shadow:0 4px 20px #0003}.request-header{text-align:center;margin-bottom:2rem}.request-header h1{margin:0 0 .5rem;color:#333;font-size:1.75rem}.request-header p{margin:0;color:#666;font-size:.95rem}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;border:1px solid #fcc}.success-message{text-align:center;padding:2rem 0}.success-message h1{color:#28a745;font-size:2rem;margin-bottom:1rem}.success-message p{color:#666;margin-bottom:1rem;line-height:1.6}.request-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;color:#333;font-weight:500;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f5f5f5;cursor:not-allowed}.form-group small{display:block;margin-top:.25rem;color:#666;font-size:.8rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn-primary{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:background .2s}.btn-primary:hover{background:#5568d3}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.form-footer{text-align:center;margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.form-footer p{margin:0;color:#666;font-size:.9rem}.form-footer a{color:#667eea;text-decoration:none;font-weight:500}.form-footer a:hover{text-decoration:underline}.App{width:100%;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
