.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative}.login-background{position:fixed;top:0;left:0;width:100%;height:100%;background-image:url(/assets/LOG_IN_PAGE2x.6ff2fb7d4368b7bb126a-6c1c699d.webp);background-size:cover;background-position:center;background-repeat:no-repeat}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;z-index:1}.login-card{background:white;border-radius:12px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 40px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-header{text-align:center;margin-bottom:40px}.login-logo{height:60px;width:auto;object-fit:contain;margin-bottom:20px}.login-title{font-size:28px;font-weight:700;color:#4caf50;margin:0 0 40px;letter-spacing:1px}.login-form{display:flex;width:50%;flex-direction:column;background-color:#fff;gap:20px}.input-group{position:relative;display:flex;align-items:center;z-index:1}.login-input{width:100%;padding:16px 20px;margin-left:10px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;background-color:#f8f9fa;transition:all .3s ease;outline:none;box-sizing:border-box;cursor:text!important;-webkit-user-select:text!important;user-select:text!important;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important}.login-input:focus{border-color:#4caf50!important;background-color:#fff!important;box-shadow:0 0 0 3px #4caf501a!important;outline:none!important}.login-input:hover{border-color:#bbb!important}.login-input::placeholder{color:#999;font-weight:400}.password-toggle{position:absolute;right:16px;background:none;border:none;cursor:pointer;color:#666;padding:4px;border-radius:4px;transition:color .2s ease;z-index:10}.password-toggle:hover{color:#4caf50}.password-toggle:focus{outline:2px solid #4caf50;outline-offset:2px}.forgot-password{text-align:right;margin:-10px 0 10px}.forgot-link{color:#4caf50;text-decoration:none;font-size:14px;font-weight:500;transition:color .2s ease}.forgot-link:hover{color:#45a049;text-decoration:underline}.login-button{width:100%;padding:16px;background-color:#4caf50;color:#fff;border:none;border-radius:8px;font-size:20px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:30px;text-align:center}.login-button:hover{background-color:#45a049;transform:translateY(-2px);box-shadow:0 8px 20px #4caf504d}.login-button:active{transform:translateY(0)}.login-button:disabled{background-color:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.login-button:focus{outline:2px solid #4caf50;outline-offset:2px}.login-error-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:2000}.login-error-modal{background:#ffffff;color:#222;border-radius:12px;padding:24px 28px;width:min(420px,90vw);box-shadow:0 20px 50px #00000040}.login-error-title{font-size:20px;font-weight:700;margin-bottom:10px}.login-error-message{font-size:16px;margin-bottom:18px;line-height:1.5}.login-error-actions{display:flex;justify-content:flex-end}@media (max-width: 480px){.login-card{padding:30px 20px;margin:20px}.login-title{font-size:24px}.login-input{padding:14px 16px;font-size:14px}.login-button{padding:14px;font-size:14px}}.login-form.loading .login-input,.login-form.loading .login-button{opacity:.7;pointer-events:none}.login-card{animation:slideInUp .6s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (prefers-contrast: high){.login-input{border-color:#000}.login-input:focus{border-color:#000!important;box-shadow:0 0 0 3px #0003!important}}.login-input{cursor:text;-webkit-user-select:text;user-select:text;-webkit-appearance:none;-moz-appearance:none;appearance:none}.login-input:focus-visible{border-color:#4caf50!important;box-shadow:0 0 0 3px #4caf501a!important;outline:none!important}.login-input:hover{border-color:#bbb}.login-page input[type=email],.login-page input[type=password],.login-page input[type=text]{border:2px solid #e0e0e0!important;background-color:#f8f9fa!important;padding:16px 20px!important;font-size:16px!important;border-radius:8px!important;outline:none!important;box-sizing:border-box!important;cursor:text!important;-webkit-user-select:text!important;user-select:text!important;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important}.login-page input[type=email]:focus,.login-page input[type=password]:focus,.login-page input[type=text]:focus{border-color:#4caf50!important;background-color:#fff!important;box-shadow:0 0 0 3px #4caf501a!important;outline:none!important}.login-page input[type=email]:hover,.login-page input[type=password]:hover,.login-page input[type=text]:hover{border-color:#bbb!important}.login-page input[type=email]:not(:disabled):not([readonly]),.login-page input[type=password]:not(:disabled):not([readonly]),.login-page input[type=text]:not(:disabled):not([readonly]){pointer-events:auto!important;opacity:1!important}.login-input:not(:disabled):not([readonly]){pointer-events:auto!important;opacity:1!important;z-index:10!important}:root{--scale-factor: 1}h1 span{font-size:.7em}.title{display:flex;justify-content:center;align-items:center;size:2rem}.loginbtn{display:flex;justify-content:center}.vertical-page-container{display:flex;flex-direction:column;min-height:100%;height:100%}.horizontal-page-container{display:flex;flex-direction:row;justify-content:flex-start}.highlight{pointer-events:none;z-index:-1}.error-message{color:red}.parking-info-dialog td{text-align:left;padding-right:10px}.map-container{position:relative;display:flex;align-items:center;justify-content:center;margin-inline:auto;max-width:100%;flex:1;min-height:0;height:100%}.map-image-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.map-container .map-image{display:block;width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain}.map-container .parking-space{position:absolute;z-index:100}.parking-garage{padding:10px;display:flex;flex-direction:column;height:75vh}.parking-garage table{width:100%;border-collapse:collapse;table-layout:fixed;flex:1;display:flex;flex-direction:column}.parking-garage thead{flex:0 0 auto}.parking-garage tbody{flex:1;display:flex;flex-direction:column}.parking-garage tr{display:flex;flex:1}.parking-garage th,.parking-garage td{border:1px solid #ddd;padding:8px;text-align:center;vertical-align:middle;flex:1;display:flex;align-items:center;justify-content:center}.parking-garage th{background-color:#f2f2f2;color:#000;font-size:2vw}.parking-garage .space-info{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:5vw;white-space:nowrap}.parking-garage button{padding:5px 10px;margin:5px;cursor:pointer}.form-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center;margin-top:10px;margin-bottom:10px}.dashboard-layout{display:flex;flex-direction:column;height:100vh;background-color:#f5f5f5}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background-color:#fff;border-bottom:1px solid #e0e0e0;height:64px;box-sizing:border-box}.header-left{display:flex;align-items:center;gap:16px}.sidebar-toggle{background:none;border:none;cursor:pointer;padding:8px;border-radius:4px;color:#666;transition:background-color .2s}.sidebar-toggle:hover{background-color:#f0f0f0}.logo-section{display:flex;align-items:center;gap:12px}.logo-image{height:40px;width:auto;object-fit:contain}.logo-text-container{display:flex;flex-direction:column}.logo-text{font-size:20px;font-weight:600;color:#333;margin:0;line-height:1.2}.logo-subtitle{font-size:12px;color:#666;margin:0;line-height:1.2}.header-right{display:flex;align-items:center}.user-icon{color:#666;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s;text-decoration:none;display:flex;align-items:center;justify-content:center}.user-icon:hover{background-color:#f0f0f0;color:#333}.sidebar{position:fixed;top:0;left:0;height:calc(100vh - 64px);background-color:#fff;border-right:1px solid #e0e0e0;transition:width .25s ease,padding .25s ease;z-index:1000;overflow:hidden;display:flex;flex-direction:column;align-items:stretch;padding:8px}.sidebar.sidebar-closed{width:72px}.sidebar.sidebar-open{width:250px}.logo-toggle{background:none;border:0;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.logo-image{display:block;object-fit:contain}.logo-large{height:40px;width:auto}.logo-small{height:36px;width:36px}.sidebar-nav{padding:8px 0}.nav-collapsed .nav-item{gap:0;justify-content:center;padding:12px 0}.nav-item-icon-only .nav-label{display:none}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:#333;text-decoration:none;transition:all .2s;border-left:3px solid transparent}.nav-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:#333}.hidden-when-collapsed{display:none}.nav-item:hover{background-color:#f8f9fa;color:#333}.nav-item-active{background-color:#e3f2fd;color:#1565c0;border-left-color:#1565c0}.nav-item-active .nav-icon{color:#1565c0}.nav-label{font-size:13px;font-weight:500;font-family:sans-serif}.auth-prompt{margin-top:24px;padding:16px;background-color:#f8f9fa;border-radius:8px;text-align:center}.auth-prompt-text{font-size:12px;color:#666;margin:0 0 12px}.auth-prompt-link{display:inline-block;padding:8px 16px;background-color:#1565c0;color:#fff;text-decoration:none;border-radius:4px;font-size:12px;font-weight:500;transition:background-color .2s}.auth-prompt-link:hover{background-color:#0d47a1;color:#fff}.main-content{flex:1;height:100vh;margin-left:0;transition:margin-left .3s ease;display:flex;flex-direction:column;overflow:hidden}.main-content.sidebar-open{margin-left:250px}.main-content.sidebar-close{margin-left:70px}.content-wrapper{padding:24px;flex:1;min-height:0;overflow-y:auto}.dashboard{background-color:#fff;border-radius:8px;padding:32px;box-shadow:0 2px 4px #0000001a}.dashboard-header{margin-bottom:32px}.dashboard-title{font-size:28px;font-weight:700;color:#333;margin:0 0 8px}.dashboard-subtitle{font-size:16px;color:#666;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px}.stats-card{display:flex;align-items:center;gap:16px;padding:24px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.stats-card-pink{background-color:#fce4ec}.stats-card-purple{background-color:#f3e5f5}.stats-card-orange{background-color:#fff3e0}.stats-card-green{background-color:#e8f5e8}.stats-card-blue{background-color:#e3f2fd}.stats-card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:8px;background-color:#fffc}.stats-card-icon svg{color:#e53e3e}.stats-card-green .stats-card-icon svg{color:#38a169}.stats-card-content{flex:1}.stats-card-title{font-size:14px;font-weight:500;color:#666;margin:0 0 8px}.stats-card-value{font-size:24px;font-weight:700;color:#333;margin:0}.dashboard-footer{background-color:#f8f9fa;border-top:1px solid #e0e0e0;padding:16px 24px;margin-top:auto}.footer-content{text-align:center}.footer-content p{margin:0;color:#666;font-size:14px}@media (max-width: 768px){.sidebar{width:100%}.main-content.sidebar-open{margin-left:0}.stats-grid{grid-template-columns:1fr}.dashboard{padding:16px}.dashboard-title{font-size:24px}}html,body,#root{height:100%}body{margin:0;padding:0}.app-spinner-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:3000}.app-spinner{background:#ffffff;border-radius:12px;padding:24px 28px;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:0 18px 40px #00000040}.app-spinner-ring{width:44px;height:44px;border:4px solid #cfe8d1;border-top-color:#4caf50;border-radius:50%;animation:app-spin .9s linear infinite}.app-spinner-text{font-size:15px;font-weight:600;color:#2f2f2f}@keyframes app-spin{to{transform:rotate(360deg)}}
