*,*:before,*:after{box-sizing:border-box}html{font-family:Segoe UI,-apple-system,BlinkMacSystemFont,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#f3f2f1;color:#201f1e}#root{min-height:100vh}a{color:#0078d4;text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;height:auto}button,input,select,textarea{font-family:inherit}code{font-family:Cascadia Code,Fira Code,Consolas,monospace}:root{--primary: #0078d4;--primary-dark: #005a9e;--primary-light: #deecf9;--secondary: #107c10;--danger: #d13438;--warning: #ffb900;--purple: #5c2d91;--orange: #d83b01;--bg-primary: #f3f2f1;--bg-secondary: #ffffff;--bg-tertiary: #faf9f8;--text-primary: #201f1e;--text-secondary: #605e5c;--text-muted: #8a8886;--border: #edebe9;--border-dark: #c8c6c4;--header-height: 56px;--sidebar-width: 280px;--admin-sidebar-width: 240px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .15);--transition: .2s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.loader{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:spin 1s linear infinite}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:var(--text-secondary)}.loading-container p{font-size:.875rem;margin:0}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:var(--danger)}.error-container p{margin:0}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-body{display:flex;flex:1;padding-top:var(--header-height)}.main-content{flex:1;margin-left:var(--sidebar-width);padding:1.5rem;min-height:calc(100vh - var(--header-height));transition:margin-left var(--transition)}.main-content.sidebar-collapsed{margin-left:0}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1rem;z-index:1000;box-shadow:var(--shadow-sm)}.header-left{display:flex;align-items:center;gap:1rem}.menu-toggle{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--text-secondary);border-radius:4px;transition:background var(--transition)}.menu-toggle:hover{background:var(--bg-primary)}.logo{display:flex;align-items:center;gap:.5rem;color:var(--primary);cursor:pointer;font-weight:600}.logo-text{font-size:1.25rem}.tenant-name{display:flex;align-items:center;font-size:1rem;font-weight:500;color:var(--text-secondary)}.tenant-separator{margin:0 .75rem;color:var(--border-dark);font-weight:300}.header-nav{display:flex;gap:.5rem;margin-left:2rem}.nav-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;font-size:.875rem;transition:all var(--transition)}.nav-button:hover{background:var(--bg-primary);color:var(--text-primary)}.nav-button.active{background:var(--primary-light);color:var(--primary)}.header-right{margin-left:auto;display:flex;align-items:center;gap:1rem}.user-menu{position:relative}.user-button{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem .25rem .25rem;background:none;border:1px solid transparent;border-radius:20px;cursor:pointer;transition:all var(--transition)}.user-button:hover{background:var(--bg-primary)}.user-avatar{width:32px;height:32px;border-radius:50%}.user-name{font-weight:500;color:var(--text-primary)}.user-button svg.rotated{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + .5rem);right:0;width:280px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg);overflow:hidden;z-index:1001}.dropdown-user-info{display:flex;gap:.75rem;padding:1rem}.dropdown-avatar{width:48px;height:48px;border-radius:50%}.dropdown-name{font-weight:600;color:var(--text-primary)}.dropdown-email{font-size:.875rem;color:var(--text-secondary)}.dropdown-role{font-size:.75rem;color:var(--primary);text-transform:uppercase;font-weight:600;margin-top:.25rem}.dropdown-divider{height:1px;background:var(--border)}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;color:var(--text-primary);font-size:.875rem;transition:background var(--transition)}.dropdown-item:hover{background:var(--bg-primary)}.dropdown-overlay{position:fixed;inset:0;z-index:999}.sidebar{position:fixed;top:var(--header-height);left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);overflow-x:hidden;overflow-y:auto;transition:transform var(--transition);z-index:100}.sidebar:not(.open){transform:translate(-100%)}.sidebar-header{padding:1.25rem 1rem;border-bottom:1px solid var(--border)}.sidebar-header h2{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.report-count{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.sidebar-content{padding:.5rem;overflow:hidden}.report-group{margin-bottom:.25rem;overflow:hidden}.group-header{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:none;border:none;cursor:pointer;border-radius:6px;transition:background var(--transition)}.group-header:hover{background:var(--bg-primary)}.group-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--primary-light);color:var(--primary);border-radius:6px}.group-name{flex:1;text-align:left;font-weight:500;color:var(--text-primary)}.group-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-primary);padding:.125rem .5rem;border-radius:10px}.group-chevron{color:var(--text-muted);transition:transform var(--transition)}.group-chevron.expanded{transform:rotate(90deg)}.group-reports{padding-left:1rem;margin-top:.25rem}.report-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem .75rem;background:none;border:none;cursor:pointer;border-radius:6px;color:var(--text-secondary);font-size:.875rem;transition:all var(--transition);text-align:left;overflow:hidden}.report-item:hover{background:var(--bg-primary);color:var(--text-primary)}.report-item.active{background:var(--primary-light);color:var(--primary)}.report-item .report-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:var(--text-muted)}.sidebar-empty svg{opacity:.5;margin-bottom:1rem}.sidebar-empty p{font-weight:500;color:var(--text-secondary);margin-bottom:.25rem}.sidebar-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:var(--text-muted);gap:.75rem}.sidebar-loading svg{color:var(--primary)}.sidebar-loading p{font-size:.875rem;color:var(--text-secondary);margin:0}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem}.sidebar-nav .nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;border-radius:6px;color:var(--text-primary);font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all var(--transition)}.sidebar-nav .nav-item:hover{background:var(--bg-primary)}.sidebar-nav .nav-item.active{background:var(--primary-light);color:var(--primary)}.sidebar-nav .nav-item svg{flex-shrink:0}.sidebar-section-divider{padding:1rem 1rem .5rem;margin-top:.5rem;border-top:1px solid var(--border)}.sidebar-section-divider span{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.sidebar-admin .sidebar-header.admin-header{background:linear-gradient(135deg,#0078d4,#005a9e);color:#fff}.sidebar-admin .sidebar-header.admin-header h2{color:#fff}.sidebar-owner .sidebar-header.owner-header{background:linear-gradient(135deg,#5c2d91,#3b1a5c);color:#fff}.sidebar-owner .sidebar-header.owner-header h2{color:#fff}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0000004d;z-index:99}@media(max-width:768px){.sidebar{z-index:200}.sidebar-overlay{display:block}.main-content{margin-left:0}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0078d4,#005a9e);padding:1rem}.login-container{width:100%;max-width:420px;background:var(--bg-secondary);border-radius:12px;box-shadow:var(--shadow-lg);padding:2.5rem}.login-header{position:relative;text-align:center;margin-bottom:2rem}.login-header svg{color:var(--primary);margin-bottom:.5rem}.login-header h1{font-size:1.75rem;color:var(--text-primary);margin-bottom:.25rem}.login-header p{color:var(--text-secondary)}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group select,.form-group textarea{padding:.75rem 1rem;border:1px solid var(--border);border-radius:6px;font-size:1rem;transition:border-color var(--transition),box-shadow var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group input.input-readonly{background:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed}.form-group label .label-hint{font-weight:400;font-size:.75rem;color:var(--text-muted)}.form-error{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#fde7e9;color:var(--danger);border-radius:6px;font-size:.875rem}.form-info{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#e7f3ff;color:#1971c2;border-radius:6px;font-size:.875rem;margin-bottom:.5rem}.login-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background var(--transition)}.login-button:hover:not(:disabled){background:var(--primary-dark)}.login-button:disabled{opacity:.7;cursor:not-allowed}.demo-accounts{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}.demo-accounts h3{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.demo-accounts p{font-size:.75rem;color:var(--text-muted);margin-bottom:.75rem}.demo-list{display:flex;flex-direction:column;gap:.5rem}.demo-user{display:flex;align-items:center;justify-content:space-between;padding:.625rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:.875rem;color:var(--text-primary);transition:all var(--transition)}.demo-user:hover{border-color:var(--primary);background:var(--primary-light)}.role-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:.25rem .5rem;background:var(--primary);color:#fff;border-radius:4px}.title-with-info{display:flex;align-items:center;justify-content:center;gap:.5rem}.info-icon-wrapper{position:relative;display:flex;align-items:center;cursor:pointer}.info-icon{color:var(--text-muted);padding:.25rem;border-radius:50%;transition:all var(--transition)}.info-icon-wrapper:hover .info-icon{color:var(--primary);background:var(--primary-light)}.info-card{position:absolute;top:100%;left:50%;transform:translate(-50%);width:280px;margin-top:.5rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg);text-align:center;z-index:10;opacity:0;visibility:hidden;transition:opacity var(--transition),visibility var(--transition)}.info-icon-wrapper:hover .info-card{opacity:1;visibility:visible}.info-card p{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.6}.info-card a{color:var(--primary);text-decoration:none;font-weight:500}.info-card a:hover{text-decoration:underline}.dashboard{max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:1.75rem;color:var(--text-primary);margin-bottom:.25rem}.dashboard-header p{color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-secondary);border-radius:8px;box-shadow:var(--shadow-sm)}.stat-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:10px}.stat-icon.blue{background:var(--primary-light);color:var(--primary)}.stat-icon.green{background:#e5f5e5;color:var(--secondary)}.stat-icon.purple{background:#ede5f5;color:var(--purple)}.stat-icon.orange{background:#fef0e5;color:var(--orange)}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.875rem;color:var(--text-secondary)}.dashboard-section{margin-bottom:2rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-header h2{font-size:1.25rem;color:var(--text-primary)}.see-all{display:flex;align-items:center;gap:.25rem;background:none;border:none;color:var(--primary);cursor:pointer;font-size:.875rem;font-weight:500}.see-all:hover{text-decoration:underline}.reports-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.report-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:1.25rem;cursor:pointer;transition:all var(--transition)}.report-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.report-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.report-card-header svg{color:var(--primary)}.report-category{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:.25rem .5rem;background:var(--bg-primary);color:var(--text-secondary);border-radius:4px}.report-card h3{font-size:1rem;color:var(--text-primary);margin-bottom:.5rem}.report-card p{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.report-card-footer{display:flex;align-items:center;justify-content:space-between;color:var(--text-muted);font-size:.75rem}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.category-card{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px}.category-info h3{font-size:.9375rem;color:var(--text-primary);margin-bottom:.125rem}.category-info p{font-size:.75rem;color:var(--text-muted)}.category-count{font-size:1.25rem;font-weight:700;color:var(--primary)}.dashboard-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-muted)}.dashboard-empty svg{opacity:.3;margin-bottom:1rem}.dashboard-empty h2{color:var(--text-secondary);margin-bottom:.5rem}.report-view{height:calc(100vh - var(--header-height) - 3rem)}.report-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:var(--text-muted)}.report-not-found svg{opacity:.3;margin-bottom:1rem}.report-not-found h2{color:var(--text-secondary);margin-bottom:.5rem}.report-not-found button{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500}.powerbi-viewer{height:100%;display:flex;flex-direction:column;background:var(--bg-secondary);border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}.viewer-toolbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:var(--bg-tertiary)}.report-title h2{font-size:1.125rem;color:var(--text-primary);margin-bottom:.125rem}.report-title p{font-size:.8125rem;color:var(--text-secondary)}.toolbar-actions{display:flex;gap:.5rem}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;cursor:pointer;color:var(--text-secondary);transition:all var(--transition)}.toolbar-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.viewer-container{flex:1;position:relative}.viewer-loading,.viewer-error{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-secondary)}.viewer-loading p{margin-top:1rem;color:var(--text-secondary)}.viewer-error{color:var(--danger)}.viewer-error h3{margin:.5rem 0}.viewer-error p{color:var(--text-secondary);margin-bottom:1rem}.viewer-error button{padding:.5rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:4px;cursor:pointer}.powerbi-embed{width:100%;height:100%}.demo-placeholder{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#f5f7fa,#e4e8ec)}.demo-content{text-align:center;max-width:500px}.demo-icon{font-size:4rem;margin-bottom:1rem}.demo-content h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:1rem}.demo-content p{color:var(--text-secondary);margin-bottom:.5rem}.demo-content code{background:var(--bg-tertiary);padding:.125rem .5rem;border-radius:4px;font-size:.75rem}.demo-info{display:flex;align-items:flex-start;gap:.75rem;margin-top:1.5rem;padding:1rem;background:var(--primary-light);border-radius:8px;text-align:left;font-size:.8125rem;color:var(--primary-dark)}.demo-chart{display:flex;align-items:flex-end;justify-content:center;gap:.75rem;height:120px;margin-top:2rem}.chart-bar{width:40px;background:linear-gradient(180deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:4px 4px 0 0;animation:grow 1s ease-out forwards;transform-origin:bottom}@keyframes grow{0%{transform:scaleY(0)}to{transform:scaleY(1)}}.admin-layout{display:flex;gap:1.5rem;min-height:calc(100vh - var(--header-height) - 3rem)}.admin-sidebar{width:var(--admin-sidebar-width);background:var(--bg-secondary);border-radius:8px;padding:1rem;height:fit-content;position:sticky;top:calc(var(--header-height) + 1.5rem)}.admin-sidebar-header{display:flex;align-items:center;gap:.5rem;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--border);color:var(--primary)}.admin-sidebar-header h2{font-size:1rem}.admin-nav{display:flex;flex-direction:column;gap:.25rem}.admin-nav a{display:flex;align-items:center;gap:.75rem;padding:.75rem;color:var(--text-secondary);text-decoration:none;border-radius:6px;font-size:.875rem;transition:all var(--transition)}.admin-nav a:hover{background:var(--bg-primary);color:var(--text-primary)}.admin-nav a.active{background:var(--primary-light);color:var(--primary);font-weight:500}.admin-content{flex:1;min-width:0}.admin-content.full-width{width:100%}.admin-unauthorized{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:var(--text-muted)}.admin-unauthorized svg{color:var(--danger);opacity:.5;margin-bottom:1rem}.admin-unauthorized h2{color:var(--text-secondary);margin-bottom:.5rem}.admin-unauthorized button{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer}.admin-reports,.admin-groups,.admin-permissions{background:var(--bg-secondary);border-radius:8px;padding:1.5rem}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.admin-header h1{font-size:1.25rem;color:var(--text-primary);margin-bottom:.25rem}.admin-header p{font-size:.875rem;color:var(--text-secondary)}.btn-primary{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background var(--transition)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-primary:disabled:hover{background:var(--primary)}.btn-secondary{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all var(--transition)}.btn-secondary:hover{background:var(--bg-primary)}.btn-secondary:disabled:hover{background:var(--bg-tertiary)}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;cursor:pointer;color:var(--text-secondary);border-radius:4px;transition:all var(--transition)}.btn-icon:hover{background:var(--bg-primary);color:var(--primary)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.btn-icon:disabled:hover{background:none;color:var(--text-secondary)}.btn-icon.danger:hover{background:#fde7e9;color:var(--danger)}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.search-box{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-muted)}.search-box input{border:none;background:none;outline:none;font-size:.875rem;width:200px}.result-count{font-size:.875rem;color:var(--text-muted)}.admin-table-container{overflow-x:auto;position:relative}.table-loading-overlay{position:absolute;inset:0;background:rgba(var(--bg-primary-rgb, 255, 255, 255),.8);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;z-index:10;color:var(--text-secondary);font-size:.875rem}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.admin-table th{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-tertiary)}.admin-table tr:hover{background:var(--bg-tertiary)}.admin-table tr.row-deleting{opacity:.5;pointer-events:none}.report-cell{display:flex;align-items:center;gap:.75rem;font-weight:500}.report-cell svg{color:var(--primary)}.group-cell{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.group-cell svg{color:var(--text-muted)}.group-cell .ungrouped{color:var(--text-muted);font-style:italic}.description-cell{max-width:300px;color:var(--text-secondary);font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-badge{font-size:.75rem;padding:.25rem .5rem;background:var(--bg-primary);border-radius:4px;color:var(--text-secondary)}.tenant-badge-primary{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;padding:.25rem .625rem;background:var(--primary);border-radius:4px;color:#fff;font-weight:500}.admin-table code{font-size:.75rem;background:var(--bg-tertiary);padding:.125rem .375rem;border-radius:3px}.action-buttons{display:flex;gap:.25rem}.table-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-muted)}.table-empty svg{opacity:.3;margin-bottom:.5rem}.groups-list{display:flex;flex-direction:column;gap:.5rem}.group-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;transition:border-color var(--transition)}.group-card:hover{border-color:var(--border-dark)}.group-drag{color:var(--text-muted);cursor:grab}.group-order{display:flex;flex-direction:column;align-items:center;gap:.125rem}.order-btn{padding:.125rem .375rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:3px;cursor:pointer;font-size:.625rem;color:var(--text-muted)}.order-btn:hover:not(:disabled){background:var(--primary-light);color:var(--primary)}.order-btn:disabled{opacity:.3;cursor:not-allowed}.group-card .group-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--primary-light);color:var(--primary);border-radius:8px}.group-card .group-info{flex:1}.group-card .group-info h3{font-size:1rem;color:var(--text-primary);margin-bottom:.125rem}.group-card .group-info p{font-size:.8125rem;color:var(--text-secondary);margin-bottom:.25rem}.group-card .report-count{font-size:.75rem;color:var(--text-muted)}.group-actions{display:flex;gap:.25rem}.groups-empty,.groups-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:var(--text-muted);text-align:center}.groups-loading svg{color:var(--primary);margin-bottom:1rem}.groups-loading p{color:var(--text-secondary)}.groups-empty svg{opacity:.3;margin-bottom:1rem}.groups-empty p{margin-bottom:1rem;color:var(--text-secondary)}.view-toggle{display:flex;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;overflow:hidden}.view-toggle button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:none;cursor:pointer;font-size:.8125rem;color:var(--text-secondary);transition:all var(--transition)}.view-toggle button:hover{background:var(--bg-primary)}.view-toggle button.active{background:var(--primary);color:#fff}.permissions-by-user{display:grid;grid-template-columns:300px 1fr;gap:1.5rem}.user-selector h3{font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem}.user-list{display:flex;flex-direction:column;gap:.5rem}.user-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all var(--transition)}.user-item:hover{border-color:var(--border-dark)}.user-item.selected{border-color:var(--primary);background:var(--primary-light)}.user-item .user-avatar{width:40px;height:40px;border-radius:50%}.user-item .user-info{flex:1;text-align:left}.user-item .user-name{display:block;font-weight:500;color:var(--text-primary)}.user-item .user-email{font-size:.75rem;color:var(--text-muted)}.user-item .perm-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-secondary);padding:.25rem .5rem;border-radius:4px}.no-users-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--bg-tertiary);border:1px dashed var(--border);border-radius:8px;text-align:center;color:var(--text-muted)}.no-users-message svg{opacity:.5;margin-bottom:.75rem}.no-users-message p{font-weight:500;color:var(--text-secondary);margin-bottom:.25rem}.no-users-message span{font-size:.75rem}.admin-access-note{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem;background:var(--primary-light);border:1px solid var(--primary);border-radius:6px;font-size:.75rem;color:var(--primary-dark)}.admin-access-note svg{flex-shrink:0}.report-permissions{background:var(--bg-tertiary);border-radius:8px;padding:1rem}.permissions-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.permissions-header h3{font-size:1rem;color:var(--text-primary)}.permissions-list{display:flex;flex-direction:column;gap:.5rem;max-height:500px;overflow-y:auto}.permission-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px}.permission-item.has-access{border-color:var(--secondary);background:#f0fff0}.permission-item .report-info{display:flex;align-items:center;gap:.75rem}.permission-item .report-info svg{color:var(--primary)}.permission-item .report-info .report-name{display:block;font-weight:500}.permission-item .report-info .report-desc{font-size:.75rem;color:var(--text-muted)}.permission-controls{display:flex;gap:.5rem}.perm-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;cursor:pointer;font-size:.75rem;color:var(--text-secondary);transition:all var(--transition)}.perm-btn:hover{border-color:var(--border-dark)}.perm-btn.view.active{background:#e5f5e5;border-color:var(--secondary);color:var(--secondary)}.perm-btn.edit.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:var(--text-muted);background:var(--bg-tertiary);border-radius:8px}.no-selection svg{opacity:.3;margin-bottom:.5rem}.permissions-matrix{overflow-x:auto;margin-top:1rem}.matrix-table{width:100%;border-collapse:collapse}.matrix-table th,.matrix-table td{padding:.75rem;border:1px solid var(--border);text-align:center}.matrix-table th{background:var(--bg-tertiary)}.matrix-table th.report-col,.matrix-table td.report-col{text-align:left;min-width:200px}.matrix-table td.report-col{display:flex;align-items:center;gap:.5rem}.matrix-table th.user-col{width:80px}.matrix-table th.user-col img{width:28px;height:28px;border-radius:50%;margin-bottom:.25rem}.matrix-table th.user-col span{display:block;font-size:.625rem}.matrix-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:4px;cursor:pointer;background:var(--bg-tertiary);color:var(--text-muted);transition:all var(--transition)}.matrix-btn:hover{background:var(--bg-primary)}.matrix-btn.granted{background:#e5f5e5;color:var(--secondary)}.matrix-btn.granted.edit{background:var(--primary-light);color:var(--primary)}.matrix-legend{display:flex;gap:1.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-secondary)}.legend-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:3px}.legend-icon.no-access{background:var(--bg-tertiary);color:var(--text-muted)}.legend-icon.view{background:#e5f5e5;color:var(--secondary)}.legend-icon.edit{background:var(--primary-light);color:var(--primary)}.legend-icon.admin{background:var(--purple);color:#fff}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{width:100%;max-width:500px;background:var(--bg-secondary);border-radius:12px;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.125rem}.modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid var(--border);background:var(--bg-tertiary);border-radius:0 0 12px 12px}@media(max-width:1024px){.permissions-by-user{grid-template-columns:1fr}.admin-layout{flex-direction:column}.admin-sidebar{width:100%;position:static}.admin-nav{flex-direction:row;flex-wrap:wrap}}@media(max-width:768px){.header-nav,.user-name{display:none}.form-row{grid-template-columns:1fr}}.token-icon.locked{color:var(--secondary)}.token-icon.unlocked{color:var(--warning)}.token-expired-badge{margin-left:auto;font-size:.625rem;font-weight:600;padding:.125rem .375rem;background:var(--danger);color:#fff;border-radius:3px;text-transform:uppercase}.token-modal{max-width:520px}.token-modal .modal-header h2{display:flex;align-items:center;gap:.5rem}.token-expired-alert{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;background:#fde7e9;border:1px solid var(--danger);border-radius:6px;color:var(--danger);font-size:.875rem;margin-bottom:1rem}.token-expired-alert svg{flex-shrink:0;margin-top:.125rem}.token-modal textarea{font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:.75rem;resize:vertical;min-height:100px}.form-error-text{display:flex;align-items:center;gap:.375rem;color:var(--danger);font-size:.75rem;margin-top:.25rem}.token-help{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;padding:1rem;font-size:.8125rem}.token-help p{margin-bottom:.5rem}.token-help ol{margin:0;padding-left:1.25rem;color:var(--text-secondary)}.token-help li{margin-bottom:.25rem}.token-input-wrapper{position:relative}.token-input-wrapper textarea{width:100%;padding-right:3rem}.token-input-wrapper textarea.token-masked{-webkit-text-security:disc;font-family:Courier New,monospace;letter-spacing:.1em}.token-toggle-btn{position:absolute;top:.5rem;right:.5rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;padding:.375rem;cursor:pointer;color:var(--text-muted);transition:all var(--transition);display:flex;align-items:center;justify-content:center}.token-toggle-btn:hover{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-dark)}span.required{color:#d13438;font-weight:600;margin-left:2px}.token-required{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#faf9f8,#f3f2f1)}.token-required-content{text-align:center;max-width:420px}.token-icon-wrapper{display:inline-flex;align-items:center;justify-content:center;width:96px;height:96px;background:var(--primary-light);color:var(--primary);border-radius:50%;margin-bottom:1.5rem}.token-icon-wrapper.expired{background:#fde7e9;color:var(--danger)}.token-required-content h3{font-size:1.5rem;color:var(--text-primary);margin-bottom:.5rem}.token-required-content>p{color:var(--text-secondary);margin-bottom:1.5rem}.token-instructions{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:1.25rem;text-align:left}.token-instructions p{margin-bottom:.75rem;font-size:.875rem}.token-instructions ol{margin:0;padding-left:1.25rem;color:var(--text-secondary);font-size:.875rem}.token-instructions li{margin-bottom:.375rem}.admin-users{padding:1.5rem}.users-table-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}.users-table th{background:var(--bg-tertiary);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.users-table tbody tr:hover{background:var(--bg-hover)}.users-table tbody tr:last-child td{border-bottom:none}.user-cell{display:flex;align-items:center;gap:.75rem}.user-cell .user-avatar{width:36px;height:36px;border-radius:50%}.user-cell .user-name{font-weight:500}.role-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.role-badge.admin{background:var(--primary-light);color:var(--primary)}.role-badge.user{background:var(--bg-tertiary);color:var(--text-secondary)}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;cursor:pointer;transition:all .2s ease}.btn-icon:hover{background:var(--bg-tertiary)}.btn-icon.delete:hover{background:#fde7e9;color:var(--danger)}.user-count{font-size:.875rem;color:var(--text-secondary)}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-group input,.form-group select{padding:.75rem;border:1px solid var(--border);border-radius:8px;font-size:.9375rem;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group input.error{border-color:var(--danger)}.error-message{font-size:.75rem;color:var(--danger)}.password-note{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-tertiary);border-radius:8px;font-size:.875rem;color:var(--text-secondary)}.password-modal .modal-header.success{background:var(--secondary);color:#fff;border-radius:12px 12px 0 0}.success-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 1rem;background:#e5f5e5;color:var(--secondary);border-radius:50%}.success-message{text-align:center;font-size:1rem;color:var(--text-primary);margin-bottom:1.5rem}.password-display{background:var(--bg-tertiary);border-radius:8px;padding:1rem}.password-display label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.password-box{display:flex;align-items:center;gap:.5rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;padding:.75rem}.password-box code{flex:1;font-family:Consolas,Monaco,monospace;font-size:1rem;color:var(--text-primary);letter-spacing:.05em}.copy-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:var(--primary);color:#fff;cursor:pointer;transition:all .2s ease}.copy-btn:hover{background:var(--primary-dark)}.password-warning{margin-top:.75rem;font-size:.8125rem;color:var(--warning);text-align:center}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:transparent;color:var(--text-primary);border:1px solid var(--border);border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:var(--bg-tertiary)}.owner-layout{min-height:100vh;display:flex;padding-top:var(--header-height)}.owner-sidebar{width:var(--admin-sidebar-width);background:linear-gradient(180deg,#1a1a2e,#16213e);position:fixed;top:var(--header-height);left:0;height:calc(100vh - var(--header-height));display:flex;flex-direction:column;z-index:500}.owner-sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.owner-sidebar-header h2{font-size:1.25rem;font-weight:600;color:#fff;display:flex;align-items:center;gap:.75rem}.owner-sidebar-header h2 svg{color:#f59e0b}.owner-nav{padding:1rem;display:flex;flex-direction:column;gap:.25rem}.owner-nav-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:#ffffffb3;text-decoration:none;border-radius:8px;transition:all .2s ease;font-weight:500}.owner-nav-link:hover{background:#ffffff1a;color:#fff}.owner-nav-link.active{background:#f59e0b33;color:#f59e0b}.owner-content{flex:1;margin-left:var(--admin-sidebar-width);padding:2rem;background:var(--bg-primary);min-height:calc(100vh - var(--header-height))}.tenant-management{max-width:1400px;margin:0 auto}.tenant-management .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.tenant-management .page-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.tenant-management .page-header p{color:var(--text-secondary);font-size:.9375rem}.tenants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.5rem}.tenant-card{background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden;transition:all .2s ease}.tenant-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.tenant-card.deleting{opacity:.5;pointer-events:none}.tenant-card-header{padding:1.25rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:1rem}.tenant-card.inactive .tenant-card-header{background:linear-gradient(135deg,#fafafa,#f4f4f5)}.tenant-logo{width:48px;height:48px;border-radius:10px;object-fit:cover;box-shadow:var(--shadow-sm)}.tenant-card-header h3{flex:1;font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.status-badge{padding:.25rem .625rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.active{background:#107c101a;color:#107c10}.status-badge.inactive{background:#d134381a;color:#d13438}.tenant-card-body{padding:1.25rem}.tenant-info-item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.875rem;font-size:.875rem}.tenant-info-item:last-child{margin-bottom:0}.tenant-info-item svg{color:var(--text-muted);flex-shrink:0;margin-top:.125rem}.tenant-info-item strong{color:var(--text-secondary);font-weight:500;min-width:80px}.tenant-info-item span{color:var(--text-primary);word-break:break-all}.tenant-card-footer{padding:1rem 1.25rem;background:var(--bg-tertiary);border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.tenant-stats{display:flex;gap:1.5rem}.tenant-stat{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-secondary)}.tenant-stat strong{font-weight:600;color:var(--text-primary)}.tenant-actions{display:flex;gap:.5rem}.tenant-actions button{padding:.5rem .75rem;border-radius:6px;border:1px solid var(--border);background:#fff;cursor:pointer;display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--text-secondary);transition:all .2s ease}.tenant-actions button:hover{background:var(--bg-primary);color:var(--text-primary)}.tenant-actions button.delete:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.toggle-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;border-radius:6px;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:.8125rem;transition:all .2s ease}.toggle-btn.activate{color:#059669}.toggle-btn.activate:hover{background:#ecfdf5;border-color:#6ee7b7}.toggle-btn.deactivate{color:#dc2626}.toggle-btn.deactivate:hover{background:#fef2f2;border-color:#fecaca}.modal.modal-lg{width:580px;max-width:90vw}.form-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.form-section:last-of-type{border-bottom:none;margin-bottom:1rem;padding-bottom:0}.form-section h3{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.form-section-desc{font-size:.8125rem;color:var(--text-muted);margin-bottom:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-secondary)}.empty-state svg{margin-bottom:1rem;color:var(--text-muted)}.empty-state h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.empty-state p{font-size:.875rem;max-width:300px}@media(max-width:768px){.owner-sidebar{width:100%;height:auto;position:relative;top:0}.owner-content{margin-left:0;padding:1rem}.owner-layout{flex-direction:column}.owner-nav{flex-direction:row;overflow-x:auto;padding:.75rem}.tenants-grid{grid-template-columns:1fr}.tenant-card-footer{flex-direction:column;gap:1rem;align-items:stretch}.tenant-stats,.tenant-actions{justify-content:center}.form-row{grid-template-columns:1fr}}.role-badge.owner{background:#f59e0b1a;color:#d97706}.role-badge.tenant-admin{background:#5c2d911a;color:#5c2d91}.token-management{max-width:1600px;margin:0 auto}.token-management .admin-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.token-management .admin-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.token-management .admin-header p{color:var(--text-secondary);font-size:.9375rem}.token-count{font-size:.875rem;color:var(--text-muted)}.tokens-table-container{background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden}.tokens-table{width:100%;border-collapse:collapse}.tokens-table th,.tokens-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}.tokens-table th{background:var(--bg-tertiary);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.tokens-table tbody tr:hover{background:var(--bg-hover)}.tokens-table tbody tr.deleting{opacity:.5;pointer-events:none}.tokens-table tbody tr:last-child td{border-bottom:none}.tenant-cell{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--text-primary)}.tenant-cell svg{color:var(--primary)}.token-cell{display:flex;align-items:center;gap:.5rem}.token-value{font-family:Fira Code,Consolas,monospace;font-size:.75rem;background:var(--bg-tertiary);padding:.25rem .5rem;border-radius:4px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary)}.no-token{color:var(--text-muted);font-style:italic;font-size:.875rem}.expiry-cell{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.expiry-cell svg{color:var(--text-muted)}.time-remaining-cell{min-width:140px}.countdown{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:20px;font-size:.8125rem;font-weight:600;font-family:Fira Code,Consolas,monospace}.countdown.ok{background:#107c101a;color:#107c10}.countdown.warning{background:#f59e0b1a;color:#d97706}.countdown.expired{background:#d134381a;color:#d13438}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.status-badge.valid{background:#107c101a;color:#107c10}.status-badge.invalid{background:#d134381a;color:#d13438}.actions-cell{display:flex;gap:.5rem}.btn-icon-sm{padding:.25rem;border-radius:4px;border:none;background:transparent;cursor:pointer;color:var(--text-muted);transition:all .2s ease}.btn-icon-sm:hover{background:var(--bg-tertiary);color:var(--text-primary)}.form-error-banner{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#d134381a;color:#d13438;border-radius:8px;margin-bottom:1.5rem;font-size:.875rem}@media(max-width:1200px){.tokens-table-container{overflow-x:auto}.tokens-table{min-width:1000px}}@media(max-width:768px){.token-management .admin-header{flex-direction:column;gap:1rem}.token-management .admin-header .btn-primary{width:100%;justify-content:center}}input.readonly,textarea.readonly{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed;border-color:var(--border)}input.readonly:focus,textarea.readonly:focus{outline:none;border-color:var(--border);box-shadow:none}.ticks-converted-date{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.625rem .875rem;background:#0078d414;border:1px solid rgba(0,120,212,.2);border-radius:6px;font-size:.875rem;color:var(--primary)}.ticks-converted-date.valid{background:#107c1014;border-color:#107c104d;color:#107c10}.ticks-converted-date.valid strong{color:#0b5e0b}.ticks-converted-date.expired{background:#f59e0b1a;border-color:#f59e0b4d;color:#b45309}.ticks-converted-date.expired strong{color:#92400e}.ticks-converted-date.expired em{font-style:italic;font-weight:600;color:#d97706}.ticks-converted-date.error{background:#d1343814;border-color:#d134384d;color:#d13438}.ticks-converted-date svg{flex-shrink:0}.ticks-converted-date strong{font-weight:600}
