*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1a1a2e;--primary-light:#16213e;--primary-dark:#0f0f1e;--primary-rgb:26,26,46;--color-success:#28a745;--color-success-light:#20c997;--color-danger:#dc3545;--color-danger-dark:#c82333;--color-warning:#ffc107;--color-warning-dark:#ff9800;--color-info:#17a2b8;--color-info-dark:#138496;--text-primary:#2c3e50;--text-secondary:#6c757d;--text-light:#adb5bd;--text-white:#fff;--bg-primary:#f8f9fa;--bg-secondary:#fff;--bg-card:#fff;--bg-hover:#f1f3f5;--border-color:#e0e6ed;--border-light:#f0f2f5;--border-hover:#1a1a2e;--gradient-primary:linear-gradient(135deg,#1a1a2e,#16213e);--gradient-success:linear-gradient(135deg,#28a745,#20c997);--gradient-danger:linear-gradient(135deg,#dc3545,#c82333);--gradient-warning:linear-gradient(135deg,#ffc107,#ff9800);--gradient-info:linear-gradient(135deg,#17a2b8,#138496);--gradient-purple:linear-gradient(135deg,#667eea,#764ba2);--gradient-pink:linear-gradient(135deg,#f093fb,#f5576c);--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001f;--shadow-xl:0 12px 48px #00000026;--transition-fast:all 0.15s ease;--transition:all 0.3s ease;--transition-slow:all 0.5s ease;--spacing-xs:0.5rem;--spacing-sm:0.75rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:8px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--radius-full:50%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;background-color:var(--bg-primary);color:#2c3e50;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease;transition:var(--transition)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:linear-gradient(135deg,#1a1a2e,#16213e);background:linear-gradient(135deg,var(--primary) 0,var(--primary-light) 100%);box-shadow:0 4px 12px #1a1a2e33;color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #1a1a2e4d;transform:translateY(-2px)}.btn-secondary{background:#fff;background:var(--bg-secondary);border:2px solid #e0e6ed;border:2px solid var(--border-color);color:#2c3e50;color:var(--text-primary)}.btn-secondary:hover:not(:disabled){border-color:#1a1a2e;border-color:var(--primary);color:#1a1a2e;color:var(--primary);transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#dc3545,#c82333);box-shadow:0 4px 12px #dc354533;color:#fff}.btn-danger:hover:not(:disabled){box-shadow:0 6px 20px #dc35454d;transform:translateY(-2px)}.btn-success{background:linear-gradient(135deg,#28a745,#218838);box-shadow:0 4px 12px #28a74533;color:#fff}.btn-success:hover:not(:disabled){box-shadow:0 6px 20px #28a7454d;transform:translateY(-2px)}.card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000f;padding:2rem;transition:all .3s ease}.card:hover{box-shadow:0 4px 16px #00000014}.card-header{margin-bottom:1.5rem}.card-header h2{color:#2c3e50;color:var(--text-primary);font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.card-header p{color:#6c757d;color:var(--text-secondary);font-size:.95rem}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{background:#f8f9fa;background:var(--bg-primary);border:2px solid #e0e6ed;border:2px solid var(--border-color);border-radius:10px;color:#2c3e50;color:var(--text-primary);font-family:inherit;font-size:.95rem;font-weight:500;padding:.875rem 1rem;transition:all .3s ease;transition:var(--transition)}.form-group input::placeholder,.form-group textarea::placeholder{color:#adb5bd;color:var(--text-light);font-weight:400}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;background:var(--bg-secondary);border-color:#1a1a2e;border-color:var(--primary);box-shadow:0 0 0 4px #1a1a2e0d;outline:none}.container{margin:0 auto;max-width:1400px;padding:2rem}.error{background:#fff5f5;border-radius:10px}.error,.success{align-items:center;display:flex;font-size:.875rem;gap:.75rem;margin-bottom:1rem;padding:.875rem 1rem}.success{background:#f0fff4;border:1px solid #9ae6b4;border-radius:10px;color:#2f855a;font-weight:500}.loading-spinner{animation:spin .8s linear infinite;border:4px solid #e0e6ed;border-top-color:#1a1a2e;border:4px solid var(--border-color);border-radius:50%;height:40px;width:40px}.loading-container{gap:1rem;padding:4rem}.loading-text{color:#6c757d;color:var(--text-secondary);font-weight:500}.login-container{background:#f8f9fa;display:flex;min-height:100vh}.login-left{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;flex:1.5 1;justify-content:center;overflow:hidden;padding:3rem;position:relative}.login-left:before{animation:pulse 8s ease-in-out infinite;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);height:500px;right:-200px;top:-200px;width:500px}.login-left:after,.login-left:before{border-radius:50%;content:"";position:absolute}.login-left:after{animation:pulse 6s ease-in-out infinite reverse;background:radial-gradient(circle,#ffffff0d 0,#0000 70%);bottom:-100px;height:300px;left:-100px;width:300px}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.login-branding{color:#fff;max-width:500px;z-index:1}.logo-container{align-items:center;display:flex;gap:1rem;margin-bottom:2rem}.logo-icon{color:#fff;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));height:60px;width:60px}.logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#e0e0e0);-webkit-background-clip:text;background-clip:text;font-size:3rem;font-weight:700;letter-spacing:-1px;margin:0}.login-tagline{color:#ffffffd9;font-size:1.25rem;font-weight:300;line-height:1.6;margin-bottom:3rem}.login-features{display:flex;flex-direction:column;gap:1.25rem}.feature-item{color:#ffffffe6;font-size:1.1rem;gap:1rem;padding:.75rem 0}.feature-icon,.feature-item{align-items:center;display:flex}.feature-icon{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-radius:50%;flex-shrink:0;font-size:.9rem;font-weight:700;height:28px;justify-content:center;width:28px}.login-right{align-items:center;background:#f8f9fa;display:flex;flex:0.8 1;justify-content:center;padding:3rem}.login-card{background:#fff;border:1px solid #0000000d;border-radius:16px;box-shadow:0 4px 24px #0000000f;max-width:450px;padding:3rem;width:100%}.login-header{margin-bottom:2.5rem;text-align:center}.login-header h2{color:#1a1a2e;font-size:1.875rem;font-weight:700;letter-spacing:-.5px;margin:0 0 .5rem}.login-header p{color:#6c757d;font-size:.95rem;font-weight:400;margin:0}.login-form{gap:1.5rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#2c3e50;font-size:.875rem;font-weight:600;letter-spacing:.3px;margin-bottom:.25rem}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#6c757d;height:20px;left:1rem;pointer-events:none;position:absolute;transition:color .2s;width:20px;z-index:1}.input-wrapper input{background:#f8f9fa;border:2px solid #e0e6ed;border-radius:10px;color:#2c3e50;font-size:.95rem;font-weight:500;padding:.875rem 1rem .875rem 3.5rem;transition:all .2s;width:100%}.input-wrapper input::placeholder{color:#adb5bd;font-weight:400}.input-wrapper input:focus{background:#fff;border-color:#1a1a2e;box-shadow:0 0 0 4px #1a1a2e0d;outline:none}.input-wrapper input:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:#1a1a2e}.input-wrapper input:disabled{cursor:not-allowed;opacity:.6}.error-message{align-items:center;animation:shake .3s ease-in-out;display:flex;font-size:.875rem;gap:.75rem;padding:.875rem 1rem}.error-icon{color:#c53030;flex-shrink:0;height:20px;width:20px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.btn-login{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e);border:none;border-radius:10px;box-shadow:0 4px 12px #1a1a2e33;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:.5rem;padding:1rem 1.5rem;transition:all .3s ease;width:100%}.btn-login:hover:not(:disabled){box-shadow:0 6px 20px #1a1a2e4d;transform:translateY(-2px)}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{cursor:not-allowed;opacity:.7}.btn-arrow{height:20px;transition:transform .2s;width:20px}.btn-login:hover:not(:disabled) .btn-arrow{transform:translateX(4px)}.spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@media (max-width:1024px){.login-left{display:none}.login-right{background:linear-gradient(135deg,#1a1a2e,#16213e);flex:1 1}.login-card{box-shadow:0 8px 32px #0003}}@media (max-width:640px){.login-right{padding:1.5rem}.login-card{border-radius:12px;padding:2rem 1.5rem}.login-header h2{font-size:1.5rem}.logo-text{font-size:2rem}.login-tagline{font-size:1rem}}.nav{background:linear-gradient(135deg,var(--primary) 0,var(--primary-light) 100%);border-bottom:1px solid #ffffff1a;box-shadow:0 2px 20px #0000001a;padding:0;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.nav-container{justify-content:space-between;margin:0 auto;max-width:1400px;padding:1rem 2rem}.nav-brand,.nav-container{align-items:center;display:flex}.nav-brand{color:#fff;font-size:1.5rem;font-weight:700;gap:.75rem;letter-spacing:-.5px;text-decoration:none}.nav-brand-icon{align-items:center;display:flex;height:32px;justify-content:center;width:32px}.nav-brand-icon svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));height:100%;width:100%}.nav-links{align-items:center;display:flex;gap:.5rem}.nav-link{border-radius:8px;color:#ffffffd9;font-size:.95rem;font-weight:500;padding:.75rem 1.25rem;position:relative;text-decoration:none;transition:all .2s}.nav-link:hover{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;color:#fff}.nav-link.active{background:#ffffff26;color:#fff}.nav-link.active:after{background:#fff;border-radius:2px;bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);width:40%}.nav .btn-secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #ffffff4d;color:#fff;font-size:.9rem;padding:.65rem 1.25rem}.nav .btn-secondary:hover{background:#ffffff40;border-color:#ffffff80;transform:translateY(-1px)}.nav-mobile-toggle{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:none;border-radius:8px;color:#fff;cursor:pointer;display:none;padding:.5rem}.nav-mobile-toggle svg{height:24px;width:24px}@media (max-width:768px){.nav-container{padding:1rem}.nav-mobile-toggle{align-items:center;display:flex;justify-content:center}.nav-links{background:linear-gradient(135deg,var(--primary) 0,var(--primary-light) 100%);border-top:1px solid #ffffff1a;box-shadow:0 10px 30px #0003;display:none;flex-direction:column;gap:0;left:0;padding:1rem;position:absolute;right:0;top:100%}.nav-links.open{display:flex}.nav-link{padding:1rem;text-align:center;width:100%}.nav .btn-secondary{justify-content:center;margin-top:.5rem;width:100%}}.dashboard-page{background:var(--bg-primary);min-height:100vh}.page-header{margin-bottom:3rem;padding-bottom:2rem}.page-header h1{margin-bottom:.5rem}.page-header p{font-size:1.1rem;font-weight:400}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-bottom:4rem}.dashboard-card{align-items:center;background:var(--bg-card);border:2px solid #0000;border-radius:20px;box-shadow:var(--shadow-sm);display:flex;gap:1.5rem;overflow:hidden;padding:2.5rem;position:relative;text-decoration:none;transition:all .3s ease}.dashboard-card:before{background:linear-gradient(135deg,var(--primary) 0,var(--primary-light) 100%);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.dashboard-card:hover:before{transform:scaleX(1)}.dashboard-card:hover{border-color:var(--border-color);box-shadow:var(--shadow-lg);transform:translateY(-8px)}.dashboard-card.qrcodes .card-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.dashboard-card.reports .card-icon{background:linear-gradient(135deg,#f093fb,#f5576c)}.card-icon{align-items:center;border-radius:16px;box-shadow:0 4px 16px #00000026;display:flex;flex-shrink:0;height:64px;justify-content:center;width:64px}.card-icon svg{color:#fff;height:32px;width:32px}.card-content{flex:1 1}.card-content h2{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.card-content p{color:var(--text-secondary);font-size:.95rem;line-height:1.5}.card-arrow{color:var(--text-light);height:24px;transition:all .3s ease;width:24px}.dashboard-card:hover .card-arrow{color:var(--primary);transform:translateX(6px)}.card-arrow svg{height:100%;width:100%}.features-section{margin-top:4rem}.features-section h2{color:var(--text-primary);font-size:2rem;font-weight:700;margin-bottom:2rem;text-align:center}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.feature-card{background:var(--bg-card);border:1px solid #0000000d;border-radius:16px;box-shadow:var(--shadow-sm);padding:2rem;text-align:center;transition:var(--transition)}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.feature-icon{filter:grayscale(.2);font-size:3rem;margin-bottom:1rem}.feature-card h3{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:.75rem}.feature-card p{color:var(--text-secondary);font-size:.95rem;line-height:1.6}@media (max-width:768px){.page-header h1{font-size:2rem}.dashboard-grid{gap:1.5rem;grid-template-columns:1fr}.dashboard-card{padding:2rem}.card-icon{height:56px;width:56px}.card-icon svg{height:28px;width:28px}.features-grid{gap:1.5rem;grid-template-columns:1fr}}.modal-content{border:1px solid #0000000d;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--spacing-2xl)}.modal-content h2{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-lg);text-align:center}.modal-actions{border-top:2px solid var(--border-light);gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg)}.modal-actions .btn{min-width:100px}@media (max-width:640px){.modal-content{padding:var(--spacing-xl);width:95%}.modal-content h2{font-size:1.5rem}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.notification-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:3000}.notification-modal{align-items:center;animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 8px 24px #0003;display:flex;flex-direction:column;gap:1.5rem;max-width:400px;padding:2rem;width:90%}.notification-icon{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:2.5rem;font-weight:700;height:64px;justify-content:center;width:64px}.notification-icon.success{background:linear-gradient(135deg,#28a745,#20c997)}.notification-icon.error{background:linear-gradient(135deg,#dc3545,#c82333)}.notification-icon.warning{background:linear-gradient(135deg,#ffc107,#ff9800)}.notification-icon.info{background:linear-gradient(135deg,#17a2b8,#138496)}.notification-message{color:#333;font-size:1rem;font-weight:500;line-height:1.5;text-align:center}.notification-close{background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:8px;box-shadow:0 2px 8px #007bff4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .2s;width:100%}.notification-close:hover{box-shadow:0 4px 12px #007bff66;transform:translateY(-2px)}.notification-close:active{transform:translateY(0)}.confirm-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:3000}.confirm-modal{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 8px 24px #0003;flex-direction:column;gap:1.5rem;max-width:400px;padding:2rem;width:90%}.confirm-icon,.confirm-modal{align-items:center;display:flex}.confirm-icon{background:linear-gradient(135deg,#ffc107,#ff9800);border-radius:50%;color:#fff;font-size:2rem;font-weight:700;height:64px;justify-content:center;width:64px}.confirm-message{color:#333;font-size:1rem;font-weight:500;line-height:1.5;text-align:center}.confirm-buttons{display:flex;gap:1rem;width:100%}.confirm-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.confirm-btn.cancel{background:#6c757d;box-shadow:0 2px 8px #6c757d4d;color:#fff}.confirm-btn.cancel:hover{background:#5a6268;box-shadow:0 4px 12px #6c757d66;transform:translateY(-2px)}.confirm-btn.confirm{background:linear-gradient(135deg,#dc3545,#c82333);box-shadow:0 2px 8px #dc35454d;color:#fff}.confirm-btn.confirm:hover{box-shadow:0 4px 12px #dc354566;transform:translateY(-2px)}.confirm-btn:active{transform:translateY(0)}.qr-modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1a1a2ebf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.qr-modal-content.advanced{animation:slideUp .3s ease;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:95vh;max-width:95vw;overflow:hidden;padding:0;width:1400px}.qr-modal-header{background:var(--bg-primary);border-bottom:2px solid var(--border-color);justify-content:space-between;padding:var(--spacing-lg);position:relative}.header-left,.qr-modal-header{align-items:center;display:flex}.header-left{gap:var(--spacing-md)}.qr-modal-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0}.settings-menu-container{position:relative}.settings-button{align-items:center;background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.4rem;height:42px;justify-content:center;transition:var(--transition);width:42px}.settings-button:hover{background:var(--bg-hover);border-color:var(--primary);color:var(--primary);transform:rotate(90deg)}.settings-dropdown{animation:slideDown .2s ease;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);left:0;min-width:250px;overflow:hidden;position:absolute;top:50px;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-menu-item{align-items:center;background:var(--bg-card);border:none;border-bottom:1px solid var(--border-light);color:var(--text-primary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:var(--transition-fast);width:100%}.settings-menu-item:hover{background:var(--bg-hover);color:var(--primary)}.settings-menu-item:disabled{cursor:not-allowed;opacity:.5}.templates-submenu{background:var(--bg-primary);border-top:1px solid var(--border-color);padding:var(--spacing-xs)}.submenu-section{margin-bottom:var(--spacing-xs)}.submenu-section:last-child{margin-bottom:0}.submenu-label{color:var(--text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.5px;margin:var(--spacing-xs) 0 var(--spacing-xs) var(--spacing-xs);text-transform:uppercase}.submenu-item{background:var(--bg-card);border:none;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:.85rem;margin-bottom:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);text-align:left;transition:var(--transition-fast);width:100%}.submenu-item:hover{background:var(--bg-hover);color:var(--primary)}.save-template-inline{display:flex;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm)}.template-name-input-inline{border:2px solid var(--border-color);border-radius:var(--radius-sm);flex:1 1;font-size:.85rem;padding:var(--spacing-xs);transition:var(--transition-fast)}.template-name-input-inline:focus{border-color:var(--primary);outline:none}.btn-confirm-inline{align-items:center;background:var(--gradient-success);border:none;border-radius:var(--radius-sm);box-shadow:0 2px 6px #28a74533;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;transition:var(--transition);width:32px}.btn-confirm-inline:hover{box-shadow:0 4px 10px #28a7454d;transform:scale(1.05)}.btn-confirm-inline:disabled{background:var(--text-light);cursor:not-allowed;transform:none}.template-item-inline{align-items:center;background:var(--bg-card);border-radius:var(--radius-sm);display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);transition:var(--transition-fast)}.template-item-inline:hover{background:var(--bg-hover)}.template-name-clickable{color:var(--text-primary);cursor:pointer;flex:1 1;font-size:.85rem;transition:var(--transition-fast)}.template-name-clickable:hover{color:var(--primary)}.btn-delete-inline{align-items:center;background:var(--gradient-danger);border:none;border-radius:var(--radius-sm);box-shadow:0 2px 4px #dc354533;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:700;height:24px;justify-content:center;transition:var(--transition);width:24px}.btn-delete-inline:hover{box-shadow:0 4px 8px #dc35454d;transform:scale(1.1)}.close-button{border-radius:var(--radius-sm);transition:var(--transition-fast)}.close-button:hover{background:var(--bg-hover);transform:rotate(90deg)}.qr-generator-container{grid-gap:0;display:grid;flex:1 1;gap:0;grid-template-columns:1fr 400px;overflow:hidden}.qr-preview-section{background:var(--bg-primary);border-right:2px solid var(--border-color);flex-direction:column;padding:var(--spacing-2xl)}.qr-preview-box,.qr-preview-section{align-items:center;display:flex;justify-content:center}.qr-preview-box{background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl);max-height:400px;max-width:400px;min-height:400px;overflow:hidden;padding:var(--spacing-lg);transition:var(--transition)}.qr-preview-box:hover{border-color:var(--border-color);box-shadow:var(--shadow-lg)}.qr-code-canvas{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.qr-code-canvas canvas,.qr-code-canvas svg{display:block!important;height:auto!important;margin:0!important;max-height:400px!important;max-width:400px!important;padding:0!important;width:auto!important}.qr-download-section{max-width:400px;width:100%}.qr-download-section h3{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 var(--spacing-md) 0;text-align:center}.download-buttons{grid-gap:var(--spacing-xs);display:grid;gap:var(--spacing-xs);grid-template-columns:repeat(4,1fr)}.btn-download{background:var(--gradient-info);border:none;border-radius:var(--radius-md);box-shadow:0 2px 6px #17a2b833;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:var(--spacing-sm) var(--spacing-md);transition:var(--transition)}.btn-download:hover{box-shadow:0 4px 12px #17a2b84d;transform:translateY(-2px)}.btn-save-customization,.btn-save-template{background:var(--gradient-success);border:none;border-radius:var(--radius-md);box-shadow:0 2px 6px #28a74533;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;margin-top:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);transition:var(--transition);width:100%}.btn-save-customization:hover,.btn-save-template:hover{box-shadow:0 4px 12px #28a7454d;transform:translateY(-2px)}.btn-save-customization:disabled,.btn-save-template:disabled{background:var(--text-light);box-shadow:none;cursor:not-allowed;transform:none}.save-template-form{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.template-name-input{border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;padding:var(--spacing-xs) var(--spacing-sm);transition:var(--transition-fast)}.template-name-input:focus{border-color:var(--primary);outline:none}.btn-confirm-template{background:var(--gradient-info);border:none;border-radius:var(--radius-sm);box-shadow:0 2px 6px #17a2b833;color:#fff;cursor:pointer;font-weight:600;padding:var(--spacing-xs);transition:var(--transition)}.btn-confirm-template:hover{box-shadow:0 4px 10px #17a2b84d;transform:translateY(-2px)}.btn-confirm-template:disabled{background:var(--text-light);cursor:not-allowed;transform:none}.templates-list{border:1px solid var(--border-color);border-radius:var(--radius-md);margin-top:var(--spacing-md);max-height:200px;overflow-y:auto}.template-item{align-items:center;background:var(--bg-card);border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:var(--spacing-sm);transition:var(--transition-fast)}.template-item:last-child{border-bottom:none}.template-item:hover{background:var(--bg-hover)}.template-name{color:var(--text-primary);flex:1 1;font-size:.85rem;font-weight:500}.template-actions{display:flex;gap:var(--spacing-xs)}.btn-apply-template,.btn-delete-template{align-items:center;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;font-size:1rem;font-weight:700;height:28px;justify-content:center;transition:var(--transition);width:28px}.btn-apply-template{background:var(--gradient-success);box-shadow:0 2px 4px #28a74533;color:#fff}.btn-apply-template:hover{box-shadow:0 4px 8px #28a7454d;transform:scale(1.1)}.btn-delete-template{background:var(--gradient-danger);box-shadow:0 2px 4px #dc354533;color:#fff}.btn-delete-template:hover{box-shadow:0 4px 8px #dc35454d;transform:scale(1.1)}.qr-controls-section{background:var(--bg-card);overflow-y:auto;scrollbar-color:var(--text-light) var(--bg-primary);scrollbar-width:thin}.controls-scroll{padding:var(--spacing-lg)}.control-group{border-bottom:2px solid var(--border-light);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg)}.control-group:last-child{border-bottom:none}.control-group h3{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 var(--spacing-md) 0}.control-item{margin-bottom:var(--spacing-md)}.control-item label{color:var(--text-primary);display:block;font-size:.9rem;font-weight:500;margin-bottom:var(--spacing-xs)}.control-item input[type=range],.control-item input[type=text],.control-item select{border:2px solid var(--border-color);border-radius:var(--radius-sm);font-family:inherit;font-size:.9rem;padding:var(--spacing-xs) var(--spacing-sm);transition:var(--transition-fast);width:100%}.control-item input[type=text]:focus,.control-item select:focus{border-color:var(--primary);outline:none}.control-item input[type=range]{cursor:pointer;padding:0}.control-item input[type=color]{border:2px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;height:40px;margin-right:var(--spacing-xs);transition:var(--transition-fast);width:60px}.control-item input[type=color]:hover{border-color:var(--primary)}.control-item .color-text{display:inline-block;width:calc(100% - 70px)}.control-item span{color:var(--primary);display:inline-block}.control-item span,.resolution-input{font-weight:600;margin-left:var(--spacing-xs)}.resolution-input{text-align:center;width:100px!important}.file-input,.resolution-input{padding:var(--spacing-xs)!important}.file-input{font-size:.9rem}.btn-remove-logo{background:var(--gradient-danger);border:none;border-radius:var(--radius-sm);box-shadow:0 2px 4px #dc354533;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;margin-top:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);transition:var(--transition);width:100%}.btn-remove-logo:hover{box-shadow:0 4px 10px #dc35454d;transform:translateY(-2px)}.control-item.checkbox{align-items:center;display:flex;flex-direction:row}.control-item.checkbox input{accent-color:var(--primary);cursor:pointer;margin-right:var(--spacing-xs);width:auto}.control-item.checkbox label{cursor:pointer;margin:0}.toggle-advanced{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-weight:600;margin-bottom:var(--spacing-md);padding:var(--spacing-sm);text-align:left;transition:var(--transition);width:100%}.toggle-advanced:hover{background:var(--bg-hover);border-color:var(--primary)}.style-grid{grid-gap:var(--spacing-xs);display:grid;gap:var(--spacing-xs);grid-template-columns:repeat(2,1fr);margin-top:var(--spacing-xs)}.style-button{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;font-weight:500;padding:var(--spacing-sm);text-transform:capitalize;transition:var(--transition)}.style-button:hover{background:var(--bg-hover);border-color:var(--primary)}.style-button.active{background:var(--gradient-primary);border-color:var(--primary);box-shadow:0 2px 6px rgba(var(--primary-rgb),.2);color:#fff;font-weight:600}.qr-controls-section::-webkit-scrollbar{width:8px}.qr-controls-section::-webkit-scrollbar-track{background:var(--bg-primary)}.qr-controls-section::-webkit-scrollbar-thumb{background:var(--text-light);border-radius:var(--radius-sm)}.qr-controls-section::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (max-width:1200px){.qr-generator-container{grid-template-columns:1fr;grid-template-rows:auto 1fr}.qr-preview-section{border-bottom:2px solid var(--border-color);border-right:none;padding:var(--spacing-lg)}.qr-preview-box{margin-bottom:var(--spacing-md)}}@media (max-width:768px){.qr-modal-content.advanced{border-radius:0;max-height:100vh;max-width:100vw;width:100%}.qr-modal-header{padding:var(--spacing-md)}.qr-modal-header h2{font-size:1.25rem}.qr-preview-section{padding:var(--spacing-md)}.qr-code-canvas canvas,.qr-code-canvas svg{max-height:280px!important;max-width:280px!important}.download-buttons{grid-template-columns:repeat(2,1fr)}.style-grid{grid-template-columns:1fr}.controls-scroll{padding:var(--spacing-md)}}.qrcode-list-page{background:var(--bg-primary);min-height:100vh}.page-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;flex-wrap:wrap;gap:var(--spacing-lg);justify-content:space-between;margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-xl)}.page-header h1{color:var(--text-primary);font-size:2.5rem;font-weight:700;letter-spacing:-1px;margin:0}.header-actions{gap:var(--spacing-sm)}.header-actions,.search-bar{align-items:center;display:flex;flex-wrap:wrap}.search-bar{background:var(--bg-card);border:1px solid #0000000d;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg)}.search-input{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);flex:1 1;font-size:.95rem;font-weight:500;min-width:250px;padding:var(--spacing-sm) var(--spacing-md);transition:var(--transition)}.search-input:focus{background:var(--bg-secondary);border-color:var(--primary);box-shadow:0 0 0 4px rgba(var(--primary-rgb),.05);outline:none}.search-input::placeholder{color:var(--text-light);font-weight:400}.btn-select-all{font-size:.9rem;padding:var(--spacing-sm) var(--spacing-lg);white-space:nowrap}.empty-state{border:1px solid #0000000d}.empty-state p{font-size:1.1rem;margin-bottom:var(--spacing-md)}.qr-grid{grid-gap:var(--spacing-xl);display:grid;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:var(--spacing-2xl)}.qr-card{align-items:center;background:var(--bg-card);border:2px solid #0000;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden;padding:var(--spacing-lg);position:relative;transition:var(--transition)}.qr-card:before{background:var(--gradient-primary);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition)}.qr-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md);transform:translateY(-4px)}.qr-card:hover:before{opacity:1}.qr-card.selected{background:linear-gradient(to bottom,rgba(var(--primary-rgb),.03),var(--bg-card));border-color:var(--primary);box-shadow:0 4px 12px rgba(var(--primary-rgb),.15)}.qr-card.selected:before{opacity:1}.qr-card-header{left:var(--spacing-md);position:absolute;top:var(--spacing-md);z-index:10}.qr-checkbox{accent-color:var(--primary);cursor:pointer;height:22px;transition:transform var(--transition-fast);width:22px}.qr-checkbox:hover{transform:scale(1.1)}.qr-image{align-items:center;background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-md);box-shadow:0 2px 8px #0000000d;display:flex;height:180px;justify-content:center;margin-bottom:var(--spacing-md);margin-top:var(--spacing-xs);overflow:hidden;padding:var(--spacing-md);position:relative;transition:var(--transition);width:180px}.qr-card:hover .qr-image{border-color:var(--border-color);box-shadow:0 4px 12px #00000014}.qr-image>div{align-items:center!important;display:flex!important;height:150px!important;justify-content:center!important;overflow:hidden!important;position:relative!important;width:150px!important}.qr-image canvas,.qr-image svg{display:block!important;height:150px!important;margin:0!important;max-height:150px!important;max-width:150px!important;object-fit:cover!important;padding:0!important;width:150px!important}.qr-info{padding:0 var(--spacing-md);text-align:center;width:100%}.qr-info h3{word-wrap:break-word;color:var(--text-primary);font-size:1.15rem;font-weight:600;margin-bottom:var(--spacing-sm)}.qr-id,.qr-link,.qr-url{color:var(--text-secondary);font-size:.85rem;line-height:1.5;margin-bottom:var(--spacing-xs);word-break:break-all}.qr-download-quick{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md);margin:var(--spacing-md) 0;padding:var(--spacing-md);width:100%}.download-label{color:var(--text-secondary);display:block;font-size:.8rem;font-weight:600;letter-spacing:.5px;margin-bottom:var(--spacing-sm);text-align:left;text-transform:uppercase}.download-quick-buttons{grid-gap:var(--spacing-xs);display:grid;gap:var(--spacing-xs);grid-template-columns:repeat(2,1fr)}.btn-download-quick{background:var(--gradient-info);border:none;border-radius:var(--radius-sm);box-shadow:0 2px 6px #17a2b833;color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;padding:var(--spacing-xs) var(--spacing-sm);transition:var(--transition)}.btn-download-quick:hover{box-shadow:0 4px 10px #17a2b84d;transform:translateY(-2px)}.qr-actions{grid-gap:var(--spacing-xs);display:grid;gap:var(--spacing-xs);grid-template-columns:repeat(2,1fr);margin-top:var(--spacing-md);width:100%}.qr-actions .btn{font-size:.85rem;padding:var(--spacing-sm) var(--spacing-md)}.loading{color:var(--text-secondary);font-size:1.2rem;padding:var(--spacing-2xl);text-align:center}.error{background-color:#fff5f5;border:1px solid #feb2b2;border-radius:var(--radius-md);color:#c53030;font-weight:500;margin-bottom:var(--spacing-md);padding:var(--spacing-md)}@media (max-width:768px){.qr-grid{gap:var(--spacing-lg);grid-template-columns:1fr}.page-header{align-items:stretch;flex-direction:column}.page-header h1{font-size:2rem}.header-actions{justify-content:stretch}.header-actions button{flex:1 1}.search-bar{flex-direction:column}.btn-select-all,.search-input{width:100%}.qr-actions{grid-template-columns:1fr}.download-quick-buttons{grid-template-columns:repeat(2,1fr)}}.qr-card{animation:fadeIn .3s ease}.qr-card:first-child{animation-delay:.05s}.qr-card:nth-child(2){animation-delay:.1s}.qr-card:nth-child(3){animation-delay:.15s}.qr-card:nth-child(4){animation-delay:.2s}.reports-page{background:var(--bg-primary);min-height:100vh}.reports-container{margin:0 auto;max-width:1400px;padding:var(--spacing-xl)}.reports-header{border-bottom:2px solid var(--border-color);margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-xl);text-align:center}.reports-header h1{color:var(--text-primary);font-size:2.5rem;font-weight:700;letter-spacing:-1px;margin-bottom:var(--spacing-sm)}.reports-subtitle{color:var(--text-secondary);font-size:1.1rem;font-weight:400}.filters-card{margin-bottom:var(--spacing-xl)}.filter-form{grid-gap:var(--spacing-md);align-items:end;display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.view-tabs{border-bottom:2px solid var(--border-color);display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-xl);overflow-x:auto;padding-bottom:0;scrollbar-width:thin}.view-tab{background:none;border:none;border-bottom:3px solid #0000;bottom:-2px;color:var(--text-secondary);cursor:pointer;font-size:1rem;font-weight:600;padding:var(--spacing-md) var(--spacing-lg);position:relative;transition:var(--transition-fast);white-space:nowrap}.view-tab:hover{background:var(--bg-hover);color:var(--primary)}.view-tab.active{background:var(--bg-card);border-bottom-color:var(--primary);color:var(--primary)}.stats-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:var(--spacing-xl)}.stat-card{align-items:center;background:var(--bg-card);border-left:4px solid #0000;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;gap:var(--spacing-md);overflow:hidden;padding:var(--spacing-lg);position:relative;transition:var(--transition)}.stat-card:before{content:"";height:100%;left:0;position:absolute;top:0;transition:width var(--transition);width:4px}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.stat-card:hover:before{width:8px}.stat-card.primary{border-left-color:var(--primary)}.stat-card.primary:before{background:var(--gradient-primary)}.stat-card.success{border-left-color:var(--color-success)}.stat-card.success:before{background:var(--gradient-success)}.stat-card.info{border-left-color:var(--color-info)}.stat-card.info:before{background:var(--gradient-info)}.stat-card.warning{border-left-color:var(--color-warning)}.stat-card.warning:before{background:var(--gradient-warning)}.stat-icon{font-size:2.5rem;opacity:.8;transition:transform var(--transition)}.stat-card:hover .stat-icon{transform:scale(1.1)}.stat-content h3{color:var(--text-secondary);font-size:.85rem;font-weight:600;letter-spacing:.5px;margin:0 0 var(--spacing-xs) 0;text-transform:uppercase}.stat-number{color:var(--text-primary);font-size:2rem;font-weight:700;margin:0}.stat-content small{color:var(--text-light);font-size:.85rem}.card{background:var(--bg-card);border:1px solid #0000000d;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-xl);padding:var(--spacing-xl);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-md)}.card h2{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0 0 var(--spacing-lg) 0}.chart-card{overflow:hidden}.charts-row{grid-gap:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.charts-row,.location-grid{display:grid;gap:var(--spacing-xl)}.location-grid{grid-gap:var(--spacing-xl);grid-template-columns:2fr 1fr}.map-card{grid-column:span 1}.map-container{height:500px;overflow:hidden;width:100%}.map-container,.map-legend{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-md)}.map-legend{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-md);padding:var(--spacing-md)}.map-legend small{color:var(--text-secondary);font-size:.85rem}.rankings{display:flex;flex-direction:column;gap:var(--spacing-lg)}.ranking-card{padding:var(--spacing-lg)}.ranking-card h3{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0 0 var(--spacing-md) 0}.ranking-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.ranking-item{align-items:center;background:var(--bg-primary);border:1px solid #0000;border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);transition:var(--transition)}.ranking-item:hover{background:var(--bg-hover);border-color:var(--border-color);transform:translateX(4px)}.ranking-position{color:var(--primary);font-size:1.1rem;font-weight:700;min-width:35px;text-align:center}.ranking-name{color:var(--text-primary);flex:1 1;font-weight:500}.ranking-badge{background:var(--gradient-primary);border-radius:var(--radius-lg);box-shadow:0 2px 6px rgba(var(--primary-rgb),.2);color:#fff;font-size:.85rem;font-weight:600;padding:.25rem var(--spacing-sm)}.table-responsive{border-radius:var(--radius-md);overflow-x:auto}.report-table{border-collapse:collapse;width:100%}.report-table thead{background:var(--bg-primary)}.report-table td,.report-table th{border-bottom:1px solid var(--border-color);padding:var(--spacing-md);text-align:left}.report-table th{color:var(--text-primary);font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.report-table tbody tr{transition:var(--transition-fast)}.report-table tbody tr:hover{background:var(--bg-hover)}.badge{border-radius:var(--radius-lg);font-size:.85rem;font-weight:600;padding:.35rem var(--spacing-sm)}.badge-primary{background:rgba(var(--primary-rgb),.1);color:var(--primary)}.badge-success{background:#28a7451a;color:var(--color-success)}.progress-bar-container{background:var(--border-light);border-radius:var(--radius-lg);height:24px;overflow:hidden;position:relative;width:150px}.progress-bar{background:var(--gradient-success);border-radius:var(--radius-lg);height:100%;transition:width var(--transition)}.progress-text{color:var(--text-primary);font-size:.85rem;font-weight:600;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.detail-section{margin-bottom:var(--spacing-xl)}.detail-section h3{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:var(--spacing-md)}.chips-container{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.chip{align-items:center;background:rgba(var(--primary-rgb),.1);border:1px solid #0000;border-radius:var(--radius-xl);color:var(--primary);display:inline-flex;font-size:.9rem;font-weight:500;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);transition:var(--transition)}.chip:hover{background:rgba(var(--primary-rgb),.15);border-color:var(--primary);transform:scale(1.05)}.chip-city{background:#667eea1a;color:#6a1b9a}.chip-city:hover{background:#667eea33}.chip-count{background:#fff;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;padding:.15rem var(--spacing-xs)}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:var(--spacing-2xl)}.loading-spinner{animation:spin 1s linear infinite;border-top:4px solid var(--border-light);border:4px solid var(--border-light);border-radius:var(--radius-full);border-top-color:var(--primary);height:50px;margin-bottom:var(--spacing-md);width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.empty-state{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-2xl) var(--spacing-xl);text-align:center}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-md);opacity:.5}.empty-state p{color:var(--text-secondary);font-size:1.25rem;margin-bottom:var(--spacing-xs)}.empty-state small{color:var(--text-light);font-size:.95rem}.no-data{color:var(--text-light);font-style:italic;padding:var(--spacing-md);text-align:center}@media (max-width:1200px){.location-grid{grid-template-columns:1fr}.map-card{grid-column:span 1}.charts-row{grid-template-columns:1fr}}@media (max-width:768px){.reports-container{padding:var(--spacing-md)}.reports-header h1{font-size:2rem}.filter-form{grid-template-columns:1fr}.view-tabs{overflow-x:auto;padding-bottom:var(--spacing-xs)}.view-tab{font-size:.9rem;padding:var(--spacing-sm) var(--spacing-md);white-space:nowrap}.stats-grid{grid-template-columns:1fr}.map-container{height:350px}.card{padding:var(--spacing-lg)}.report-table{font-size:.85rem}.report-table td,.report-table th{padding:var(--spacing-sm)}.charts-row{grid-template-columns:1fr}}.card,.stat-card{animation:fadeIn .4s ease}.user-management-page{background:var(--bg-primary);min-height:100vh}.page-header p{color:var(--text-secondary);font-size:1rem;margin-top:.5rem}.users-table-container{background:var(--bg-card);border:1px solid #0000000d;border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden}.users-table{border-collapse:collapse;width:100%}.users-table thead{background:var(--bg-primary)}.users-table th{border-bottom:2px solid var(--border-color);font-size:.875rem;font-weight:600;letter-spacing:.5px;text-align:left;text-transform:uppercase}.users-table td,.users-table th{color:var(--text-primary);padding:1rem}.users-table td{border-bottom:1px solid var(--border-color)}.users-table tbody tr{transition:var(--transition)}.users-table tbody tr:hover{background:var(--bg-primary)}.role-badge,.status-badge{border-radius:12px;display:inline-block;font-size:.875rem;font-weight:600;padding:.35rem .85rem}.role-badge.role-admin{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.role-badge.role-user{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.status-badge.status-confirmed{background:#e8f5e9;color:#2e7d32}.status-badge.status-force_change_password{background:#fff5f5;color:#c53030}.actions-cell{display:flex;gap:.5rem}.btn-small{border-radius:8px;font-size:.875rem;padding:.5rem .85rem}.btn-warning{background:linear-gradient(135deg,#ffd89b,#19547b);border:none;box-shadow:0 2px 8px #ffc10733;color:#fff;cursor:pointer;font-weight:600;transition:var(--transition)}.btn-warning:hover:not(:disabled){box-shadow:0 4px 12px #ffc1074d;transform:translateY(-2px)}.empty-state,.loading{background:var(--bg-card);border-radius:16px;box-shadow:var(--shadow-sm);color:var(--text-secondary);padding:4rem 2rem;text-align:center}.error-message{background:#fff5f5;border:1px solid #feb2b2;border-radius:10px;color:#c53030;font-weight:500;margin:1rem 0;padding:1rem}.modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1a1a2eb3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease;background:var(--bg-card);border-radius:20px;box-shadow:var(--shadow-lg);max-height:90vh;max-width:500px;overflow-y:auto;padding:2.5rem;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.modal-header h2{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0}.close-button{background:none;border:none;border-radius:8px;color:var(--text-light);cursor:pointer;font-size:2rem;height:2rem;line-height:1;padding:0;transition:var(--transition);width:2rem}.close-button:hover{background:var(--bg-primary);color:var(--primary)}.modal-actions{border-top:1px solid var(--border-color);display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem}@media (max-width:768px){.page-header{align-items:flex-start;flex-direction:column;gap:1rem}.users-table-container{overflow-x:auto}.users-table{font-size:.875rem}.users-table td,.users-table th{padding:.75rem .5rem}.actions-cell{flex-direction:column}.modal-content{padding:1.5rem}}.app-container{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;padding-top:var(--spacing-xl)}
/*# sourceMappingURL=main.a77d03c3.css.map*/