@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap";.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width-expanded);height:100vh;background:var(--sidebar-bg);display:flex;flex-direction:column;z-index:1000;transition:width var(--transition-speed) ease,transform var(--transition-speed) ease}.sidebar--collapsed{width:var(--sidebar-width-collapsed)}.sidebar-header{background:linear-gradient(180deg,rgba(255,255,255,.15) 0%,transparent 100%);padding:16px 20px;display:flex;align-items:center;gap:12px;min-height:60px;transition:padding var(--transition-speed) ease}.sidebar--collapsed .sidebar-header{padding:16px 12px;justify-content:center}.sidebar-logo{display:flex;align-items:center;color:var(--text-white);font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden}.sidebar-logo-icon-collapsed{display:none;width:28px;height:auto}.sidebar--collapsed .sidebar-logo-icon-collapsed{display:block}.sidebar-logo-text{display:flex;align-items:center;gap:6px;opacity:1;transition:opacity var(--transition-speed) ease}.sidebar--collapsed .sidebar-logo-text{opacity:0;width:0;overflow:hidden;display:none}.sidebar-logo-eventify{height:1.1em;width:auto;vertical-align:middle}.sidebar-toggle{position:absolute;right:-14px;top:72px;width:28px;height:28px;background:var(--sidebar-bg);border:2px solid var(--content-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:transform var(--transition-speed) ease}.sidebar-toggle svg{width:14px;height:14px;stroke:var(--text-white);transition:transform var(--transition-speed) ease}.sidebar--collapsed .sidebar-toggle svg{transform:rotate(180deg)}.sidebar-nav{flex:1;padding:12px;overflow-y:auto;overflow-x:hidden}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:var(--text-light);font-size:14px;cursor:pointer;transition:all .2s;white-space:nowrap;text-decoration:none;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--sidebar-bg-hover)}.nav-item--active{background:var(--sidebar-bg-dark);color:var(--text-white)}.nav-item-icon{width:20px;height:20px;min-width:20px;display:flex;align-items:center;justify-content:center}.nav-item-icon svg{width:20px;height:20px}.nav-item-content{flex:1;display:flex;align-items:center;justify-content:space-between;opacity:1;transition:opacity var(--transition-speed) ease}.sidebar--collapsed .nav-item-content{opacity:0;width:0;overflow:hidden}.sidebar--collapsed .nav-item{justify-content:center;padding:10px}.nav-item-chevron{width:16px;height:16px;transition:transform .2s}.nav-item-chevron svg{width:16px;height:16px}.nav-item--expanded .nav-item-chevron{transform:rotate(180deg)}.nav-group{margin-bottom:4px}.nav-submenu{max-height:0;overflow:hidden;transition:max-height .3s ease;margin-left:16px}.nav-submenu--open{max-height:300px}.sidebar--collapsed .nav-submenu{display:none}.nav-item--sub{padding:8px 12px;font-size:13px;color:var(--text-muted);gap:10px}.nav-item--sub:hover,.nav-item--sub.nav-item--active{color:var(--text-white);background:var(--sidebar-bg-dark)}.nav-item--sub .nav-item-icon{width:18px;height:18px;min-width:18px}.nav-item--sub .nav-item-icon svg{width:18px;height:18px}.sidebar-footer{padding:16px;border-top:1px solid var(--sidebar-border-color);margin-top:auto}.user-info{display:flex;align-items:center;gap:12px}.user-avatar{width:36px;height:36px;min-width:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:600}.user-details{flex:1;min-width:0;opacity:1;transition:opacity var(--transition-speed) ease}.sidebar-footer .user-name{font-size:14px;font-weight:600;color:#fff}.sidebar-footer .user-email{font-size:12px;color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-logout{background:none;border:none;padding:8px;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .2s}.user-logout svg{width:18px;height:18px;stroke:#fff9}.user-logout:hover{background:var(--sidebar-bg-hover)}.user-logout:hover svg{stroke:#fff}.sidebar--collapsed .user-info{justify-content:center}.sidebar--collapsed .user-avatar,.sidebar--collapsed .user-details{display:none}.sidebar--collapsed .user-logout{padding:10px}.sidebar--collapsed .user-logout svg{width:22px;height:22px}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:999;opacity:0;transition:opacity var(--transition-speed) ease;pointer-events:none}.sidebar-overlay--visible{opacity:1;pointer-events:auto}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:var(--sidebar-width-expanded)}.sidebar--mobile-open{transform:translate(0)}.sidebar--collapsed{width:var(--sidebar-width-expanded)}.sidebar-toggle{display:none}.sidebar-overlay{display:block}.sidebar--collapsed .sidebar-logo-text,.sidebar--collapsed .nav-item-content,.sidebar--collapsed .user-details,.sidebar--collapsed .user-logout{opacity:1;width:auto;overflow:visible;padding:8px}.sidebar--collapsed .nav-item{justify-content:flex-start;padding:10px 12px}.sidebar--collapsed .user-info{justify-content:flex-start}}.topbar{display:flex;align-items:center;justify-content:space-between;height:var(--topbar-height);padding:0 24px;background-color:var(--card-bg);border-bottom:1px solid var(--border-color);position:fixed;top:0;left:var(--sidebar-width-expanded);right:0;z-index:100;transition:left var(--transition-speed) ease}.app-shell--sidebar-collapsed .topbar{left:var(--sidebar-width-collapsed)}.topbar-left{display:flex;align-items:center;gap:12px}.mobile-menu-btn{display:none;width:40px;height:40px;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;border-radius:var(--radius-md);padding:0}.mobile-menu-btn:hover{background:#0000000d}.mobile-menu-btn svg{width:24px;height:24px;stroke:var(--text-primary)}.topbar-icon{color:var(--text-secondary);display:flex;align-items:center;justify-content:center}.topbar-icon svg{width:20px;height:20px}.topbar-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.topbar-user{display:flex;align-items:center}@media (max-width: 768px){.topbar{left:0;padding:0 16px}.mobile-menu-btn{display:flex}.topbar-title{font-size:16px}}.app-shell{display:flex;min-height:100vh;background-color:var(--content-bg)}.app-shell-main{flex:1;margin-left:var(--sidebar-width-expanded);display:flex;flex-direction:column;transition:margin-left var(--transition-speed) ease}.app-shell--sidebar-collapsed .app-shell-main{margin-left:var(--sidebar-width-collapsed)}.app-shell-content{flex:1;padding:24px;margin-top:var(--topbar-height)}@media (max-width: 768px){.app-shell-main{margin-left:0!important}.app-shell-content{padding:16px}}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:transparent;border:none;cursor:pointer;border-radius:4px;transition:background-color .2s}.user-menu-trigger:hover{background-color:#f0f0f0}.user-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:#00d4aa;color:#fff;font-weight:600;border-radius:50%}.user-name{font-size:.875rem;color:#333}.user-menu-arrow{font-size:.625rem;color:#666}.user-menu-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:199}.user-menu-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;min-width:200px;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 4px 12px #0000001a;z-index:200}.user-menu-header{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.25rem}.user-menu-email{font-size:.875rem;color:#333}.user-menu-role{font-size:.75rem;color:#666;text-transform:capitalize}.user-menu-divider{height:1px;background-color:#e0e0e0}.user-menu-item{display:block;width:100%;padding:.75rem 1rem;background:transparent;border:none;text-align:left;font-size:.875rem;color:#333;cursor:pointer;transition:background-color .2s}.user-menu-item:hover{background-color:#f5f5f5}.user-menu-item--danger{color:#e53935}.user-menu-item--danger:hover{background-color:#ffebee}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:#f5f5f5}.loading-screen-content{text-align:center}.loading-spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#00d4aa;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:1rem;color:#666}.session-expired-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.session-expired-modal{background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 24px #0003;max-width:400px;text-align:center}.session-expired-icon{font-size:3rem;margin-bottom:1rem}.session-expired-title{font-size:1.25rem;font-weight:600;color:#333;margin:0 0 .5rem}.session-expired-message{font-size:1rem;color:#666;margin:0 0 1.5rem}.session-expired-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#fff;background-color:#00d4aa;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.session-expired-button:hover{background-color:#00b894}.session-expired-button:focus{outline:2px solid #00d4aa;outline-offset:2px}.forbidden-view{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:#f5f5f5;padding:2rem}.forbidden-content{text-align:center;max-width:400px;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.forbidden-icon{font-size:4rem;margin-bottom:1rem}.forbidden-title{font-size:1.5rem;font-weight:600;color:#333;margin:0 0 .5rem}.forbidden-message{font-size:1rem;color:#666;margin:0 0 1rem}.forbidden-role{font-size:.875rem;color:#888;margin:0 0 1.5rem}.forbidden-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#fff;background-color:#00d4aa;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.forbidden-button:hover{background-color:#00b894}.auth-screen{--auth-primary: #540F76;--auth-primary-hover: #6B1399;--auth-background: #FAFAFA;--auth-text-primary: #181D27;--auth-text-secondary: #717680;--auth-text-muted: #A4A7AE;--auth-border: #D5D7DA;--auth-white: #FFFFFF}.auth-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:var(--auth-background);padding:20px;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.auth-container{display:flex;width:100%;max-width:1280px;min-height:680px;background:var(--auth-white);border-radius:16px;box-shadow:0 0 16px #0a0d120a;overflow:hidden}.auth-content-section{flex:1;padding:60px 80px;display:flex;flex-direction:column;max-width:520px}.auth-logo-section{margin-bottom:60px}.auth-logo-text{font-size:26px;font-weight:700;display:flex;align-items:center;gap:8px}.auth-logo-signagelive{color:var(--auth-text-primary)}.auth-logo-by{color:var(--auth-text-secondary)}.auth-logo-eventify{display:flex;align-items:center}.auth-logo-eventify img{height:1.2em;width:auto;vertical-align:middle}.auth-header{margin-bottom:40px}.auth-title{font-size:24px;font-weight:600;color:var(--auth-text-primary);margin:0 0 8px}.auth-subtitle{font-size:14px;color:var(--auth-text-secondary);margin:0}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center}.auth-loading-text{font-size:16px;color:var(--auth-text-secondary);margin:0 0 24px}.auth-spinner{width:40px;height:40px;border:3px solid var(--auth-border);border-top-color:var(--auth-primary);border-radius:50%;animation:auth-spin 1s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-image-section{flex:1.2;position:relative;background:url(/assets/login-splash.jpg) center center / cover no-repeat;display:flex;align-items:center;justify-content:center;min-height:500px}.auth-stand-image{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);height:80%;max-height:500px;object-fit:contain}@media (max-width: 1024px){.auth-container{max-width:500px}.auth-content-section{max-width:100%;padding:40px}.auth-image-section{display:none}}@media (max-width: 600px){.auth-screen{padding:0}.auth-container{min-height:100vh;border-radius:0}.auth-content-section{padding:30px 24px}.auth-logo-section{margin-bottom:40px}.auth-header{margin-bottom:30px}.auth-title{font-size:24px}}.screen-placeholder{padding:1rem}.screen-title{font-size:1.5rem;font-weight:600;color:#333;margin:0 0 .5rem}.screen-description{font-size:.875rem;color:#666;margin:0}.admin-screen{padding:var(--spacing-lg);max-width:1200px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.admin-header h1{font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text-primary);margin:0}.admin-filters{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.admin-search{flex:1;min-width:200px;max-width:400px}.admin-search input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg-input);color:var(--color-text-primary);transition:border-color .2s ease}.admin-search input:focus{outline:none;border-color:var(--color-primary)}.admin-search input::placeholder{color:var(--color-text-muted)}.admin-filter-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg-input);color:var(--color-text-primary);cursor:pointer;min-width:150px}.admin-table-container{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border)}.admin-table th{background:var(--color-bg-secondary);font-weight:600;font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.admin-table tbody tr:hover{background:var(--color-bg-hover)}.admin-table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.025em}.badge--role-admin{background:var(--color-primary-light);color:var(--color-primary)}.badge--role-user{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.badge--status-active{background:var(--color-success-light);color:var(--color-success)}.badge--status-disabled{background:var(--color-warning-light);color:var(--color-warning)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn--secondary{background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-bg-hover)}.btn--danger{background:var(--color-danger);color:#fff}.btn--danger:hover:not(:disabled){background:var(--color-danger-dark)}.btn--ghost{background:transparent;color:var(--color-text-secondary);padding:var(--spacing-xs)}.btn--ghost:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text-primary)}.btn--sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}.admin-form{max-width:500px}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary)}.form-label--required:after{content:" *";color:var(--color-danger)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--color-bg-input);color:var(--color-text-primary);transition:border-color .2s ease}.form-input:focus{outline:none;border-color:var(--color-primary)}.form-input::placeholder{color:var(--color-text-muted)}.form-input--error{border-color:var(--color-danger)}.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--color-bg-input);color:var(--color-text-primary);cursor:pointer}.form-error{margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-danger)}.form-hint{margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-muted)}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl)}.user-detail{max-width:600px}.user-detail-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.user-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.user-detail-title{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.user-detail-email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.user-detail-badges{display:flex;gap:var(--spacing-sm)}.user-detail-section{margin-bottom:var(--spacing-lg)}.user-detail-section:last-child{margin-bottom:0}.user-detail-section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-md)}.admin-empty{padding:var(--spacing-2xl);text-align:center;color:var(--color-text-muted)}.admin-empty-icon{font-size:3rem;margin-bottom:var(--spacing-md);opacity:.5}.admin-empty-title{font-size:var(--font-size-lg);font-weight:500;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.admin-empty-description{font-size:var(--font-size-sm)}.admin-loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--color-text-muted)}.admin-error{padding:var(--spacing-lg);background:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger);margin-bottom:var(--spacing-lg)}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);max-width:400px;width:90%;box-shadow:var(--shadow-lg)}.dialog-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.dialog-content{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.dialog-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md)}.actions-cell{display:flex;gap:var(--spacing-xs)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-width-expanded: 240px;--sidebar-width-collapsed: 64px;--sidebar-bg: #540F76;--sidebar-bg-dark: #3d0a57;--sidebar-bg-hover: rgba(255, 255, 255, .1);--sidebar-header-gradient: linear-gradient(135deg, #e84c9e 0%, #c93d8f 100%);--sidebar-border-color: rgba(255, 255, 255, .15);--accent-green: #22d866;--accent-pink: #d946a8;--text-white: #ffffff;--text-light: rgba(255, 255, 255, .85);--text-muted: rgba(255, 255, 255, .6);--text-primary: #181D27;--text-secondary: #717680;--content-bg: #f5f5f5;--card-bg: #ffffff;--border-color: #e5e5e5;--color-error: #DC2626;--color-success: #16A34A;--color-warning: #D97706;--color-info: #2563EB;--font-family: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-base: 16px;--line-height-base: 1.5;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--sidebar-width: var(--sidebar-width-expanded);--topbar-height: 60px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-card: 0 2px 8px rgba(0, 0, 0, .04);--transition-speed: .25s}html{font-size:var(--font-size-base);line-height:var(--line-height-base)}body{font-family:var(--font-family);color:var(--text-primary);background-color:var(--content-bg);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.screen-placeholder{padding:var(--spacing-md)}.screen-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-sm)}.screen-description{font-size:.875rem;color:var(--text-secondary);margin:0}.content-card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--spacing-lg)}
