*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;color:#333;background:#f5f5f5}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background:#fff;border-bottom:1px solid #e0e0e0;padding:1rem 2rem}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:600;color:#333;cursor:pointer}.nav{display:flex;gap:1.5rem}.nav a{color:#666;text-decoration:none;transition:color .2s}.nav a:hover{color:#333}.main{flex:1 1;max-width:1200px;width:100%;margin:0 auto 2rem;padding:0 2rem}.footer{background:#fff;border-top:1px solid #e0e0e0;padding:1rem 2rem;color:#666}.footer,.welcome{text-align:center}.welcome{padding:4rem 2rem}.welcome h1{font-size:3rem;margin-bottom:1rem}.welcome p{font-size:1.25rem;color:#666;margin-bottom:2rem}.btn-primary{display:inline-block;background:#000;color:#fff;padding:.75rem 2rem;border:1px solid #000;border-radius:0;text-decoration:none;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;transition:all .2s ease;cursor:pointer;-webkit-tap-highlight-color:transparent}.btn-primary:hover{background:#fff;color:#000;border-color:#000}.btn-primary:active{opacity:.8}.loading{text-align:center;padding:2rem;font-size:1.25rem;color:#666}.timeline-container{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 2px 4px rgba(0,0,0,.1)}.timeline-container h1{margin-bottom:1rem}.users-container{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 2px 4px rgba(0,0,0,.1)}.users-header{justify-content:space-between;margin-bottom:2rem}.header-left,.users-header{display:flex;align-items:center}.header-left{gap:1rem}.btn-add{background:#fff;color:#333;padding:0;border:1px solid #ddd;border-radius:50%;cursor:pointer;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:600;font-size:1.25rem;line-height:1;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.btn-add:hover{background:#333;color:#fff;border-color:#333}.btn-add:active{opacity:.8}.filter-group{display:flex;gap:.5rem;align-items:center}.filter-group label{font-weight:500}.filter-group select{padding:.5rem;border:1px solid #ddd;border-radius:.25rem;font-size:.9rem}.error-message{background:#fee;color:#c00;padding:1rem;border-radius:.5rem;margin-bottom:1rem;border:1px solid #fcc}.users-table{overflow-x:auto}.users-table table{width:100%;border-collapse:collapse}.users-table th{text-align:left;padding:.75rem;background:#f5f5f5;border-bottom:2px solid #ddd;font-weight:600}.users-table td{padding:.75rem;border-bottom:1px solid #eee}.users-table tr.no-role{background:#fffbf0}.users-table tr:hover{background:#f9f9f9}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:1rem;font-size:.85rem;font-weight:500}.role-badge.role-super_admin{background:#e3f2fd;color:#1976d2}.role-badge.role-edit{background:#f3e5f5;color:#7b1fa2}.role-badge.role-view{background:#e8f5e9;color:#388e3c}.role-badge.role-none{background:#fef3e0;color:#f57c00}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:1rem;font-size:.85rem;font-weight:500}.status-badge.status-active{background:#e8f5e9;color:#2e7d32}.status-badge.status-pending{background:#fff3e0;color:#f57c00}.btn-edit{background:#000;color:white;border:1px solid #000;padding:.5rem 1rem;border-radius:0;cursor:pointer;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.btn-edit:hover{background:#fff;color:#000;border-color:#000}.btn-edit:active{opacity:.8}.btn-secondary{background:#fff;color:#333;border:1px solid #ddd;padding:.75rem 1.5rem;border-radius:0;cursor:pointer;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.btn-secondary:hover{background:#f5f5f5;border-color:#bbb}.btn-secondary:active{opacity:.8}.btn-edit:disabled,.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-small{background:#fff;color:#333;border:1px solid #ddd;padding:.5rem 1rem;border-radius:0;cursor:pointer;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.btn-small:hover{background:#333;color:#fff;border-color:#333}.btn-small:active{opacity:.8}.btn-danger{background:#dc3545;color:white;border:1px solid #dc3545;border-radius:0;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.btn-danger:hover{background:#c82333;border-color:#c82333}.btn-danger:active{opacity:.8}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:white;border-radius:0;border:1px solid #ddd;box-shadow:8px 8px 0 rgba(0,0,0,.15);max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #eee}.modal-header h2{margin:0;font-size:1.5rem;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:800}.modal-close{background:white;border:1px solid #ddd;font-size:1.5rem;color:#333;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.modal-close:hover{background:#333;color:white;border-color:#333}.modal-close:active{opacity:.8}.modal-body{padding:1.5rem}.modal-description{color:#666;margin-bottom:1.5rem;line-height:1.5}.email-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:.5rem;font-size:1rem;font-family:inherit}.email-input:focus{outline:none;border-color:#000;box-shadow:0 0 0 2px rgba(0,0,0,.1)}.error-box{background:#ffebee;border:1px solid #ef5350;color:#c62828;padding:1rem;border-radius:.5rem;margin-top:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #eee}.user-info{background:#f5f5f5;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem}.user-info p{margin:.5rem 0}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.role-select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:.5rem;font-size:1rem}.role-description{padding:1rem;background:#f0f7ff;border-left:4px solid #0070f3;border-radius:.25rem;margin-bottom:1rem}.role-description.warning{background:#fff8e1;border-left-color:#f57c00}.confirm-box{background:#ffebee;border:1px solid #ef5350;padding:1rem;border-radius:.5rem;margin-top:1rem}.confirm-box p{margin:.5rem 0}.admin-container{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 2px 4px rgba(0,0,0,.1)}.admin-menu{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-top:2rem}.admin-card{background:white;border:1px solid #ddd;padding:2rem;border-radius:0;text-decoration:none;color:inherit;transition:all .2s ease;cursor:pointer;-webkit-tap-highlight-color:transparent}.admin-card:hover{background:#333;color:white;border-color:#333;transform:translateY(-2px);box-shadow:4px 4px 0 rgba(0,0,0,.15)}.admin-card h2{margin:0 0 .5rem;color:inherit;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:800}.admin-card p{margin:0;color:#666;transition:color .2s ease}.admin-card:hover p{color:#ccc}@media (max-width:768px){.header{padding:.75rem}.header-content{flex-direction:column;gap:.75rem;align-items:flex-start}.main{padding:0 .5rem}.welcome h1{font-size:2rem}.welcome p{font-size:1rem}.users-container{padding:.75rem}.users-header{flex-direction:column;gap:.75rem;align-items:flex-start}.header-left{width:100%;flex-direction:row;gap:.75rem;align-items:center}.users-header h1{font-size:1.5rem}.filter-group{width:100%;flex-direction:column;align-items:flex-start}.filter-group select{width:100%}.users-table{overflow-x:visible}.users-table table{display:block}.users-table thead{display:none}.users-table tbody{display:block}.users-table tr{display:block;margin-bottom:1rem;background:white;border:1px solid #ddd;border-radius:.5rem;padding:.75rem}.users-table tr.no-role{background:#fffbf0;border-color:#ffd966}.users-table td{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;border-bottom:1px solid #eee}.users-table td:last-child{border-bottom:none;margin-top:.4rem}.users-table td:before{content:attr(data-label);font-weight:600;color:#666;flex-shrink:0;margin-right:1rem}.btn-edit{width:100%;padding:.75rem}.admin-menu{grid-template-columns:1fr}.admin-card{padding:1.25rem}.admin-container{padding:.75rem}}@media (max-width:480px){.welcome{padding:1.5rem .5rem}.welcome h1{font-size:1.5rem}.btn-primary{padding:.65rem 1.5rem;font-size:.9rem}.main{padding:0 .25rem}.users-container{padding:.5rem}.users-table tr{padding:.5rem;margin-bottom:.75rem}.users-table td{flex-direction:column;align-items:flex-start;gap:.25rem;padding:.35rem 0}.users-table td:before{margin-right:0;margin-bottom:.25rem}.admin-card{padding:1rem}.admin-container{padding:.5rem}}