.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff,#dbeafe,#bfdbfe);position:relative;overflow:hidden}.login-box{background:var(--color-white);border-radius:0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;width:100%;max-width:420px;padding:2.5rem;position:relative;z-index:10;border:1px solid var(--color-gray-200)}.login-header{text-align:center;margin-bottom:2rem}.logo{display:flex;flex-direction:column;align-items:center;gap:1rem}.logo-icon{width:64px;height:64px;background:var(--color-primary-600);color:var(--color-white);border-radius:0;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 6px -1px #2563eb4d}.logo-image{width:80px;height:80px;object-fit:contain;margin-bottom:.5rem}.logo-text h1{font-size:1.75rem;font-weight:700;color:var(--color-primary-800);letter-spacing:-.025em;margin:0}.logo-text p{font-size:.875rem;color:var(--color-gray-500);margin-top:.25rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.error-message{background-color:var(--color-sell-bg);color:var(--color-sell);padding:.75rem 1rem;font-size:.875rem;border-left:3px solid var(--color-sell)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--color-gray-700)}.form-group input{padding:.75rem 1rem;border:1px solid var(--color-gray-300);font-size:.9375rem;background:var(--color-white);transition:all .2s}.form-group input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #3b82f61a}.form-group input::placeholder{color:var(--color-gray-400)}.password-input{position:relative}.password-input input{width:100%;padding-right:2.5rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-gray-400);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s}.password-toggle:hover{color:var(--color-gray-600)}.login-button{background:var(--color-primary-600);color:var(--color-white);border:none;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem;transition:all .2s;box-shadow:0 2px 4px #2563eb33}.login-button:hover:not(:disabled){background:var(--color-primary-700);box-shadow:0 4px 6px #2563eb4d}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--color-gray-200);text-align:center}.login-footer p{font-size:.8125rem;color:var(--color-gray-500);margin:.25rem 0}.login-footer strong{color:var(--color-gray-700);font-family:monospace;background:var(--color-gray-100);padding:.125rem .375rem}.login-background{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 50%,rgba(59,130,246,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(37,99,235,.1) 0%,transparent 50%)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;transition:width .3s ease;z-index:100}.sidebar.expanded{width:var(--sidebar-expanded)}.sidebar-logo{height:64px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(255,255,255,.1);padding:0 1rem;gap:.75rem}.logo-icon-small{width:40px;height:40px;background:#ffffff26;border-radius:0;display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0}.logo-image{width:40px;height:40px;object-fit:contain;flex-shrink:0}.logo-text{color:var(--color-white);font-size:1.25rem;font-weight:700;white-space:nowrap;overflow:hidden}.sidebar-nav{flex:1;padding:1rem 0;display:flex;flex-direction:column;gap:.25rem}.nav-item{display:flex;align-items:center;padding:.875rem 1.25rem;color:#fffc;text-decoration:none;transition:all .2s;gap:1rem;position:relative}.nav-item:hover{background:var(--sidebar-hover);color:var(--color-white)}.nav-item.active{background:var(--sidebar-active);color:var(--color-white)}.nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:#60a5fa}.nav-label{font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden}.sidebar-toggle{position:absolute;right:-12px;top:80px;width:24px;height:24px;background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-gray-600);box-shadow:0 2px 4px #0000001a;transition:all .2s;z-index:101}.sidebar-toggle:hover{background:var(--color-primary-50);color:var(--color-primary-600);transform:scale(1.1)}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:.75rem}.user-avatar{width:36px;height:36px;background:#ffffff26;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-white);font-weight:600;font-size:.875rem;flex-shrink:0}.user-info{display:flex;flex-direction:column;overflow:hidden}.user-name{color:var(--color-white);font-size:.875rem;font-weight:500;white-space:nowrap}.user-role{color:#fff9;font-size:.75rem;white-space:nowrap}.header{height:64px;background:var(--color-white);border-bottom:1px solid var(--color-gray-200);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center}.page-title{font-size:1.25rem;font-weight:600;color:var(--color-gray-800);margin:0}.header-right{display:flex;align-items:center;gap:1rem}.header-search{display:flex;align-items:center;gap:.5rem;background:var(--color-gray-100);padding:.5rem .875rem;border:1px solid var(--color-gray-200);width:280px}.header-search svg{color:var(--color-gray-400)}.header-search input{border:none;background:transparent;font-size:.875rem;outline:none;width:100%;color:var(--color-gray-700)}.header-search input::placeholder{color:var(--color-gray-400)}.header-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;padding:.5rem;color:var(--color-gray-500);transition:all .2s;position:relative}.header-btn:hover{color:var(--color-primary-600);background:var(--color-primary-50)}.notification-btn{position:relative}.badge{position:absolute;top:2px;right:2px;width:16px;height:16px;background:var(--color-danger);color:var(--color-white);font-size:.625rem;font-weight:600;border-radius:50%;display:flex;align-items:center;justify-content:center}.user-menu{display:flex;align-items:center;gap:.5rem;padding-left:.75rem;border-left:1px solid var(--color-gray-200)}.user-btn{gap:.5rem;padding:.5rem .75rem}.user-btn .user-name{font-size:.875rem;font-weight:500;color:var(--color-gray-700)}.logout-btn:hover{color:var(--color-sell);background:var(--color-sell-bg)}.user-menu{position:relative}.user-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--color-white);border:1px solid var(--color-gray-200);box-shadow:0 4px 12px #00000026;border-radius:.5rem;min-width:200px;z-index:100;padding:.5rem 0}.dropdown-header{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.25rem}.dropdown-username{font-weight:600;color:var(--color-gray-800);font-size:.9375rem}.dropdown-role{font-size:.75rem;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.025em}.dropdown-divider{height:1px;background:var(--color-gray-200);margin:.5rem 0}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem 1rem;background:transparent;border:none;cursor:pointer;font-size:.875rem;color:var(--color-gray-700);text-align:left;transition:all .15s}.dropdown-item:hover{background:var(--color-gray-50);color:var(--color-gray-900)}.dropdown-item.logout-item{color:var(--color-danger)}.dropdown-item.logout-item:hover{background:var(--color-danger-bg)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal-content{background:var(--color-white);border-radius:.5rem;box-shadow:0 4px 20px #00000026;padding:1.5rem;width:100%;max-width:420px;max-height:90vh;overflow-y:auto}.modal-content h2{margin:0 0 1.25rem;font-size:1.25rem;font-weight:600;color:var(--color-gray-800)}.modal-error{background:var(--color-danger-bg);color:var(--color-danger);padding:.75rem 1rem;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem}.modal-success{background:var(--color-success-bg);color:var(--color-success);padding:.75rem 1rem;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem}.form-group input,.form-group select{width:100%;padding:.625rem .875rem;border:1px solid var(--color-gray-300);border-radius:.375rem;font-size:.875rem;background:var(--color-white);transition:all .15s}.btn{padding:.625rem 1.25rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.blotter-view{display:flex;flex-direction:column;gap:1.5rem}.action-bar{display:flex;justify-content:space-between;align-items:center}.action-left{display:flex;gap:.75rem}.action-right{display:flex;gap:.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all .2s;border-radius:0}.btn-primary:hover{background:var(--color-primary-700);box-shadow:0 2px 4px #2563eb4d}.btn-secondary{background:var(--color-white);color:var(--color-gray-700);border:1px solid var(--color-gray-300);position:relative}.btn-secondary:hover{background:var(--color-gray-50);border-color:var(--color-gray-400)}.btn-icon{padding:.625rem;background:var(--color-white);color:var(--color-gray-500);border:1px solid var(--color-gray-200);border-radius:0}.btn-icon:hover:not(:disabled){background:var(--color-gray-50);color:var(--color-primary-600)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.btn-text{background:transparent;color:var(--color-primary-600);padding:.5rem}.btn-text:hover{color:var(--color-primary-700);text-decoration:underline}.filter-badge{position:absolute;top:-4px;right:-4px;width:16px;height:16px;background:var(--color-danger);color:var(--color-white);font-size:.625rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}.filter-panel{background:var(--color-white);border:1px solid var(--color-gray-200);padding:1.25rem;box-shadow:var(--card-shadow)}.filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.filter-group{display:flex;flex-direction:column;gap:.375rem}.filter-group label{font-size:.75rem;font-weight:600;color:var(--color-gray-600);text-transform:uppercase;letter-spacing:.025em}.filter-group input,.filter-group select{padding:.5rem .75rem;border:1px solid var(--color-gray-300);font-size:.875rem;background:var(--color-white)}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 2px #3b82f61a}.filter-actions{display:flex;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-gray-200)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:var(--color-white);border:1px solid var(--color-gray-200);padding:1.25rem;box-shadow:var(--card-shadow);display:flex;flex-direction:column;gap:.5rem}.stat-label{font-size:.75rem;font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.025em}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-gray-800)}.table-card{background:var(--color-white);border:1px solid var(--color-gray-200);box-shadow:var(--card-shadow)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem;color:var(--color-gray-500)}.table-container{overflow-x:auto}.trades-table{width:100%;font-size:.8125rem}.trades-table th{background:var(--color-gray-50);font-weight:600;color:var(--color-gray-700);padding:.75rem 1rem;border-bottom:1px solid var(--color-gray-200);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.trades-table th:hover{background:var(--color-gray-100)}.trades-table th.numeric{text-align:right}.sort-icon{vertical-align:middle;margin-left:.25rem;color:var(--color-gray-400)}.sort-icon.active{color:var(--color-primary-600)}.trades-table td{padding:.875rem 1rem;border-bottom:1px solid var(--color-gray-100);vertical-align:middle}.trade-row:hover td{background:var(--color-primary-50)}.trade-row:last-child td{border-bottom:none}.trades-table td.numeric{text-align:right;font-family:SF Mono,Monaco,monospace}.security-cell{display:flex;flex-direction:column;gap:.125rem}.ticker{font-weight:600;color:var(--color-gray-800)}.sec-type{font-size:.6875rem;color:var(--color-gray-500);text-transform:uppercase}.direction-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em}.direction-badge.buy{background:var(--color-buy-bg);color:var(--color-buy)}.direction-badge.sell{background:var(--color-sell-bg);color:var(--color-sell)}.pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-top:1px solid var(--color-gray-200);background:var(--color-gray-50)}.pagination-info{font-size:.875rem;color:var(--color-gray-600)}.pagination-controls{display:flex;gap:.5rem}.blotter-content{position:relative}.panel-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:100;display:flex;justify-content:flex-end;animation:fadeIn .2s ease-out}.trade-row{cursor:pointer}.trade-row.selected td,.trade-row.selected:hover td{background:var(--color-primary-100)}.splits-col{width:40px;text-align:center;padding:.5rem!important}.split-icon{color:var(--color-primary-500);vertical-align:middle}.trade-detail-panel{width:30%;min-width:350px;max-width:500px;background:var(--color-white);border-left:1px solid var(--color-gray-200);box-shadow:-4px 0 20px #00000026;display:flex;flex-direction:column;height:100%;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOut{0%{transform:translate(0)}to{transform:translate(100%)}}.trade-detail-panel.closing{animation:slideOut .2s ease-in forwards}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-gray-200);background:var(--color-gray-50)}.panel-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-gray-800)}.btn-close{display:flex;align-items:center;justify-content:center;padding:.375rem;background:transparent;border:none;cursor:pointer;color:var(--color-gray-500);border-radius:0;transition:all .2s}.btn-close:hover{background:var(--color-gray-200);color:var(--color-gray-700)}.panel-content{flex:1;overflow-y:auto;padding:1rem}.detail-section{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-gray-100)}.detail-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.detail-section h4{display:flex;align-items:center;gap:.5rem;margin:0 0 .5rem;font-size:.6875rem;font-weight:600;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.025em}.trade-header-info{display:flex;align-items:center;gap:1rem}.trade-id{font-size:1.125rem;font-weight:700;color:var(--color-gray-800)}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem .75rem}.detail-item{display:flex;flex-direction:column;gap:.125rem}.detail-item.full-width{grid-column:1 / -1}.detail-item label{font-size:.6875rem;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.025em}.detail-item value{font-size:.875rem;color:var(--color-gray-800);font-weight:500}.detail-item value.highlight{color:var(--color-primary-600);font-weight:600}.status-done{display:inline-flex;align-items:center;gap:.25rem;color:#059669;font-weight:500}.status-pending{display:inline-flex;align-items:center;gap:.25rem;color:#d97706;font-weight:500}.loading-splits{padding:1rem;text-align:center;color:var(--color-gray-500);font-size:.875rem}.splits-table{width:100%;font-size:.8125rem;background:var(--color-white);border:1px solid var(--color-gray-200);margin-top:.5rem}.splits-table th{background:var(--color-gray-100);font-weight:600;color:var(--color-gray-700);padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--color-gray-200)}.splits-table th.numeric{text-align:right}.splits-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-gray-100)}.splits-table td.numeric{text-align:right;font-family:SF Mono,Monaco,monospace}.splits-table tr:last-child td{border-bottom:none}.pm-badge{display:inline-flex;align-items:center;padding:.125rem .5rem;background:var(--color-primary-100);color:var(--color-primary-700);font-size:.75rem;font-weight:600}.remarks-text{margin:0;padding:.75rem;background:var(--color-gray-50);font-size:.875rem;color:var(--color-gray-700);line-height:1.5}.detail-section.action-buttons{display:flex;flex-direction:row;justify-content:center;gap:.5rem;flex-wrap:wrap}.detail-section.action-buttons .btn{justify-content:center;padding:.5rem 1rem;min-width:90px;font-size:.8125rem;border-radius:0!important}.btn-correct{background:var(--color-primary-600);color:var(--color-white)}.btn-correct:hover{background:var(--color-primary-700)}.btn-cancel{background:var(--color-warning-bg, #fef3c7);color:var(--color-warning, #92400e);border:1px solid var(--color-warning-border, #f59e0b)}.btn-cancel:hover{background:#fde68a}.btn-delete{background:var(--color-danger-bg, #fef2f2);color:var(--color-danger, #dc2626);border:1px solid var(--color-danger-border, #fca5a5)}.btn-delete:hover{background:#fee2e2}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-page{padding:1.5rem;max-width:1200px;margin:0 auto}.admin-header{margin-bottom:1.5rem}.admin-header h1{font-size:1.75rem;font-weight:600;color:var(--color-gray-800);margin:0 0 .5rem}.admin-header p{color:var(--color-gray-500);margin:0}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-gray-200)}.tab-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--color-gray-500);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.tab-btn:hover{color:var(--color-gray-700);background:var(--color-gray-50)}.tab-btn.active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-600)}.admin-content{background:var(--color-white);border-radius:0;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.admin-error{background:#fef2f2;color:#dc2626;padding:.75rem 1rem;border-radius:0;margin-bottom:1rem;font-size:.875rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{font-size:1.125rem;font-weight:600;color:var(--color-gray-800);margin:0}.search-box{display:flex;align-items:center;gap:.5rem;background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:0;padding:.5rem .75rem;width:300px}.search-box svg{color:var(--color-gray-400)}.search-box input{border:none;background:none;outline:none;font-size:.875rem;width:100%;color:var(--color-gray-700)}.search-box input::placeholder{color:var(--color-gray-400)}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;font-size:.875rem}.users-table th{text-align:left;padding:.75rem 1rem;font-weight:600;color:var(--color-gray-600);border-bottom:1px solid var(--color-gray-200);background:var(--color-gray-50)}.users-table td{padding:.875rem 1rem;border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-700)}.users-table tbody tr:hover{background:var(--color-gray-50)}.role-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:0;font-size:.75rem;font-weight:500;text-transform:capitalize}.role-admin{background:#fef3c7;color:#92400e}.role-trader{background:#dbeafe;color:#1e40af}.role-viewer{background:#d1fae5;color:#065f46}.status-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:0;font-size:.75rem;font-weight:500}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#f3f4f6;color:#6b7280}.action-buttons{display:flex;gap:.25rem}.action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:0;background:transparent;color:var(--color-gray-500);cursor:pointer;transition:all .15s}.action-btn:hover{background:var(--color-gray-100)}.action-btn.edit:hover{color:var(--color-primary-600);background:#eff6ff}.action-btn.role:hover{color:#7c3aed;background:#f5f3ff}.action-btn.delete:hover{color:#dc2626;background:#fef2f2}.loading,.no-results{text-align:center;padding:3rem;color:var(--color-gray-500)}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.role-card{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:0;padding:1.25rem}.role-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.role-header svg{color:var(--color-primary-600)}.role-header h3{font-size:1rem;font-weight:600;color:var(--color-gray-800);margin:0;text-transform:capitalize}.role-description{color:var(--color-gray-500);font-size:.875rem;margin:0 0 1rem}.role-permissions h4{font-size:.75rem;font-weight:600;color:var(--color-gray-600);text-transform:uppercase;letter-spacing:.025em;margin:0 0 .5rem}.role-permissions ul{list-style:none;padding:0;margin:0}.role-permissions li{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--color-gray-600);padding:.25rem 0}.role-permissions li svg{color:#10b981;flex-shrink:0}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:none;border-radius:0;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-primary{background:var(--color-primary-600);color:var(--color-white)}.btn-primary:hover:not(:disabled){background:var(--color-primary-700)}.btn-secondary{background:var(--color-white);color:var(--color-gray-700);border:1px solid var(--color-gray-300)}.btn-secondary:hover{background:var(--color-gray-50)}.btn-danger{background:#dc2626;color:var(--color-white)}.btn-danger:hover{background:#b91c1c}.btn:disabled{opacity:.6;cursor:not-allowed}.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;padding:1rem}.modal-content{background:var(--color-white);border-radius:0;box-shadow:0 4px 20px #00000026;padding:1.5rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-content.modal-large{max-width:600px}.modal-content.modal-small{max-width:400px}.modal-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-gray-200)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-gray-800);flex:1}.modal-header svg{color:var(--color-primary-600)}.modal-close{background:none;border:none;color:var(--color-gray-400);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:var(--color-gray-600)}.modal-error{background:#fef2f2;color:#dc2626;padding:.75rem 1rem;border-radius:0;margin-bottom:1rem;font-size:.875rem}.modal-description{color:var(--color-gray-600);margin-bottom:1rem}.confirm-message{text-align:center;color:var(--color-gray-600);margin:1.5rem 0;line-height:1.5}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-gray-600);margin-bottom:.375rem}.form-group input,.form-group select{width:100%;padding:.625rem .875rem;border:1px solid var(--color-gray-300);border-radius:0;font-size:.875rem;background:var(--color-white);transition:all .15s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 2px #3b82f61a}.checkbox-label{display:flex!important;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;margin:0}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-gray-200)}@media (max-width: 768px){.admin-page{padding:1rem}.section-header{flex-direction:column;gap:1rem;align-items:stretch}.search-box{width:100%}.form-row{grid-template-columns:1fr}.users-table th,.users-table td{padding:.625rem .75rem}.roles-grid{grid-template-columns:1fr}}.dashboard{display:flex;min-height:100vh;background-color:var(--color-gray-100)}.dashboard-content{flex:1;display:flex;flex-direction:column;margin-left:var(--sidebar-width);transition:margin-left .3s ease}.dashboard-content.sidebar-expanded{margin-left:var(--sidebar-expanded)}.main-content{flex:1;padding:1.5rem;overflow:auto}.card{background:var(--color-white);border:1px solid var(--color-gray-200);box-shadow:var(--card-shadow)}.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--color-gray-200);background:var(--color-gray-50)}.card-header h2{font-size:1.125rem;font-weight:600;color:var(--color-gray-800);margin:0}.card-body{padding:1.25rem}.placeholder-view{max-width:800px;margin:0 auto}.placeholder-view p{font-size:1rem;text-align:center;padding:2rem}:root{--color-primary-50: #eff6ff;--color-primary-100: #dbeafe;--color-primary-200: #bfdbfe;--color-primary-300: #93c5fd;--color-primary-400: #60a5fa;--color-primary-500: #3b82f6;--color-primary-600: #2563eb;--color-primary-700: #1d4ed8;--color-primary-800: #1e40af;--color-primary-900: #1e3a8a;--color-white: #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-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #3b82f6;--color-buy: #16a34a;--color-buy-bg: #dcfce7;--color-sell: #dc2626;--color-sell-bg: #fee2e2;--sidebar-width: 64px;--sidebar-expanded: 200px;--sidebar-bg: #1e3a8a;--sidebar-hover: #1e40af;--sidebar-active: #2563eb;--card-bg: #ffffff;--card-border: #e2e8f0;--card-shadow: 0 1px 3px rgba(0, 0, 0, .1);--card-radius: 0;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--transition-fast: .15s ease;--transition-normal: .25s ease}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:var(--font-family);font-size:var(--font-size-sm);line-height:1.5;color:var(--color-gray-800);background-color:var(--color-gray-100);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.text-primary{color:var(--color-primary-600)}.text-secondary{color:var(--color-gray-500)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.bg-primary{background-color:var(--color-primary-600)}.bg-primary-light{background-color:var(--color-primary-50)}.bg-white{background-color:var(--color-white)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.animate-fadeIn{animation:fadeIn var(--transition-normal)}.animate-slideIn{animation:slideIn var(--transition-normal)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}table{width:100%;border-collapse:collapse}th,td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--color-gray-200)}th{font-weight:600;color:var(--color-gray-700);background-color:var(--color-gray-50);white-space:nowrap}tr:hover td{background-color:var(--color-primary-50)}
