@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-color: #fceceb;--surface-color: #ffffff;--surface-hover: #f1f5f9;--text-primary: #0f172a;--text-secondary: #64748b;--primary-color: #f59e0b;--primary-hover: #d97706;--accent-color: #3b82f6;--border-color: #e2e8f0;--success-color: #10b981;--error-color: #ef4444;--warning-color: #f59e0b;--font-main: "Outfit", sans-serif;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}html.dark{--bg-color: #0b0c10;--surface-color: #1f2833;--surface-hover: #2b3746;--text-primary: #f8fafc;--text-secondary: #94a3b8;--primary-color: #d4af37;--primary-hover: #b4952f;--border-color: #334155;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .5);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .5), 0 2px 4px -2px rgb(0 0 0 / .5);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .5), 0 4px 6px -4px rgb(0 0 0 / .5)}*{box-sizing:border-box;margin:0;padding:0}html,body{font-family:var(--font-main);background-color:var(--bg-color);color:var(--text-primary);min-height:100vh;transition:background-color .3s ease,color .3s ease;overflow-x:hidden}#root{display:flex;flex-direction:column;min-height:100vh}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;font-family:var(--font-main)}.btn-primary{background-color:var(--primary-color);color:#111;box-shadow:var(--shadow-sm)}.btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-1px)}.btn-outline{background-color:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.btn-outline:hover{background-color:var(--surface-hover);border-color:var(--primary-color)}.card{background-color:var(--surface-color);border-radius:1rem;box-shadow:var(--shadow-md);padding:1.5rem;border:1px solid var(--border-color);transition:all .3s ease}.input{width:100%;padding:.75rem 1rem;border-radius:.5rem;border:1px solid var(--border-color);background-color:var(--surface-hover);color:var(--text-primary);font-family:var(--font-main);transition:all .2s ease}.input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #d4af3733}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .5s ease forwards}.loader-container{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color);z-index:9999;transition:opacity .5s ease}.loader-container.fade-out{opacity:0;pointer-events:none}.loader-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.car-icon{width:64px;height:64px;color:var(--primary-color);animation:bounce 2s infinite}.car-icon svg{width:100%;height:100%}.loader-title{font-size:2.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.025em;margin:0}.loader-title span{color:var(--primary-color)}.loader-subtitle{font-size:1rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;font-weight:500}.loading-bar{width:200px;height:4px;background-color:var(--surface-hover);border-radius:999px;overflow:hidden;margin-top:1rem}.progress{width:100%;height:100%;background-color:var(--primary-color);transform-origin:left;animation:progress 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes progress{0%{transform:scaleX(0)}50%{transform:scaleX(.7)}to{transform:scaleX(1)}}.layout-root{display:flex;min-height:100vh;width:100vw;background-color:var(--bg-color);color:var(--text-primary)}.sidebar{width:260px;background-color:var(--surface-color);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:1.5rem 0;transition:all .3s ease;z-index:10}.sidebar-header{display:flex;align-items:center;gap:.75rem;padding:0 1.5rem 2rem;border-bottom:1px solid var(--border-color);margin-bottom:1.5rem}.logo-icon{color:var(--primary-color)}.sidebar-header h2{font-size:1.5rem;font-weight:700;letter-spacing:-.025em;margin:0}.sidebar-header h2 span{color:var(--primary-color)}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.5rem;padding:0 1rem}.nav-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:.5rem;color:var(--text-secondary);text-decoration:none;font-weight:500;transition:all .2s ease;background:transparent;border:none;font-family:inherit;font-size:1rem;cursor:pointer;width:100%}.nav-item:hover{background-color:var(--surface-hover);color:var(--text-primary)}.nav-item.active{background-color:var(--primary-color);color:#111;box-shadow:var(--shadow-sm)}.sidebar-footer{padding:0 1rem}.logout-btn{color:var(--error-color)}.logout-btn:hover{background-color:#ef44441a;color:var(--error-color)}.main-content{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:72px;background-color:var(--surface-color);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;position:sticky;top:0;z-index:5}.topbar-search{position:relative;width:300px}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.input-search{width:100%;padding:.5rem 1rem .5rem 2.5rem;border-radius:999px;border:1px solid var(--border-color);background-color:var(--surface-hover);color:var(--text-primary);font-family:inherit;font-size:.875rem;transition:all .2s ease}.input-search:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #d4af3733}.topbar-actions{display:flex;align-items:center;gap:1.5rem}.theme-toggle{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.theme-toggle:hover{background-color:var(--surface-hover);color:var(--text-primary)}.user-profile{display:flex;align-items:center;gap:.75rem;cursor:pointer}.avatar{width:36px;height:36px;border-radius:50%;background-color:var(--primary-color);color:#111;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem}.user-name{font-weight:500;font-size:.875rem;display:none}@media(min-width:768px){.user-name{display:block}}.page-content{flex:1;padding:2rem;overflow-y:auto}.dashboard-container{display:flex;flex-direction:column;gap:2rem}.dashboard-header h1{font-size:1.875rem;font-weight:700;margin-bottom:.25rem}.dashboard-header p{color:var(--text-secondary)}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.metric-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:1rem;padding:1.5rem;display:flex;align-items:center;gap:1.25rem;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.metric-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.metric-icon-wrapper{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center}.metric-icon-wrapper.primary{background-color:#f59e0b1a;color:var(--primary-color)}.metric-icon-wrapper.success{background-color:#10b9811a;color:var(--success-color)}.metric-icon-wrapper.warning{background-color:#ef44441a;color:var(--error-color)}.metric-info h3{font-size:.875rem;color:var(--text-secondary);font-weight:500;margin-bottom:.25rem}.metric-info .metric-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1}.dashboard-content{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}@media(max-width:1024px){.dashboard-content{grid-template-columns:1fr}}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.card-header h2{font-size:1.25rem;font-weight:600}.btn-sm{padding:.35rem .75rem;font-size:.875rem}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:.75rem;background-color:var(--surface-hover);transition:background-color .2s ease}.activity-item:hover{background-color:var(--surface-color);border:1px solid var(--border-color);margin:-1px}.activity-icon{color:var(--text-secondary);background-color:var(--surface-color);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color)}.activity-details{flex:1}.activity-plate{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.activity-meta{font-size:.875rem;color:var(--text-secondary)}.activity-status{font-size:.875rem;font-weight:600;padding:.25rem .75rem;border-radius:999px}.activity-status.parked{background-color:#10b9811a;color:var(--success-color)}.activity-status.left{background-color:#64748b1a;color:var(--text-secondary)}.capacity-visualizer{display:flex;justify-content:center;align-items:center;padding:2rem 0}.capacity-circle{width:200px;height:200px;position:relative}.circular-chart{display:block;margin:0 auto;max-width:80%;max-height:250px}.circle-bg{fill:none;stroke:var(--surface-hover);stroke-width:3.8}.circle{fill:none;stroke:var(--primary-color);stroke-width:3.8;stroke-linecap:round;animation:progressFill 1s ease-out forwards}@keyframes progressFill{0%{stroke-dasharray:0 100}}.capacity-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.capacity-text .percentage{display:block;font-size:2.5rem;font-weight:700;line-height:1;color:var(--text-primary)}.capacity-text .label{display:block;font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.booking-container{display:flex;flex-direction:column;gap:1.5rem}.booking-header{display:flex;align-items:center;justify-content:space-between}.booking-header h1{font-size:1.875rem;font-weight:700;margin-bottom:.25rem}.booking-header p{color:var(--text-secondary)}.booking-actions{display:flex;gap:1rem}.filter-group{display:flex;align-items:center;gap:.5rem;background-color:var(--surface-color);padding:.5rem 1rem;border-radius:.5rem;border:1px solid var(--border-color)}.slot-filter{background:transparent;border:none;color:var(--text-primary);font-family:inherit;font-size:.875rem;cursor:pointer;outline:none}.legend-strip{display:flex;flex-wrap:wrap;gap:1.5rem;padding:1rem 1.5rem;background-color:var(--surface-color);border-radius:.5rem;border:1px solid var(--border-color)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);font-weight:500}.color-box{width:16px;height:16px;border-radius:4px}.color-box.standard{background-color:var(--surface-hover);border:1px solid var(--border-color)}.color-box.vip{background-color:#f59e0b33;border:1px solid var(--primary-color)}.color-box.disabled{background-color:#3b82f633;border:1px solid var(--accent-color)}.color-box.occupied{background-color:var(--border-color);border:1px solid var(--text-secondary);opacity:.5}.parking-graph{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem;padding:2rem;background-color:var(--surface-color);border-radius:1rem;border:1px solid var(--border-color)}.slot-card{position:relative;height:140px;border-radius:.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;font-family:inherit;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px dashed var(--border-color);background-color:transparent;color:var(--text-primary)}.slot-card:hover:not(:disabled){border-style:solid;border-color:var(--primary-color);background-color:#f59e0b0d;transform:translateY(-2px);box-shadow:var(--shadow-sm)}.slot-card.vip{border-color:#f59e0b80;background-color:#f59e0b0d}.slot-card.vip:hover:not(:disabled){background-color:#f59e0b26;border-color:var(--primary-color)}.slot-card.disabled{border-color:#3b82f680;background-color:#3b82f60d}.slot-card.disabled:hover:not(:disabled){background-color:#3b82f626;border-color:var(--accent-color)}.slot-card.occupied{background-color:var(--surface-hover);border-color:transparent;border-style:solid;cursor:not-allowed;opacity:.7}.slot-id{font-size:1.25rem;z-index:1}.slot-icon{color:var(--primary-color)}.slot-plate{font-size:.75rem;background-color:var(--surface-color);padding:.25rem .5rem;border-radius:.25rem;border:1px solid var(--border-color);color:var(--text-secondary);position:absolute;bottom:.5rem;width:90%;text-align:center;word-break:break-all}.modal-overlay{position:fixed;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;animation:fadeIn .2s ease forwards}.modal-content{width:100%;max-width:400px;animation:slideUp .3s ease forwards}.modal-content h2{font-size:1.5rem;margin-bottom:.25rem}.modal-subtitle{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.875rem}.booking-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.retrieval-container{display:flex;flex-direction:column;gap:2rem;max-width:800px;margin:0 auto}.retrieval-header h1{font-size:1.875rem;font-weight:700;margin-bottom:.25rem;text-align:center}.retrieval-header p{color:var(--text-secondary);text-align:center}.search-section{padding:2rem}.search-input-wrapper{position:relative;display:flex;gap:1rem}.search-icon-large{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.search-input-large{flex:1;padding:1rem 1rem 1rem 3.5rem;border-radius:.75rem;border:2px solid var(--border-color);background-color:var(--surface-hover);color:var(--text-primary);font-family:inherit;font-size:1.125rem;transition:all .2s ease}.search-input-large:focus{outline:none;border-color:var(--primary-color);background-color:var(--surface-color);box-shadow:0 0 0 4px #d4af371a}.search-btn{padding:0 2rem;font-size:1rem}@media(max-width:600px){.search-input-wrapper{flex-direction:column}.search-btn{padding:1rem}}.search-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background-color:var(--surface-color);border-radius:1rem;border:1px dashed var(--border-color);color:var(--text-secondary)}.empty-icon{color:var(--border-color);margin-bottom:1rem}.search-empty h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem}.result-card{padding:2rem}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.plate-badge{font-size:1.5rem;font-weight:700;letter-spacing:2px;background-color:var(--surface-hover);padding:.5rem 1rem;border-radius:.5rem;border:2px solid var(--border-color)}.type-badge{padding:.35rem .75rem;border-radius:999px;font-size:.875rem;font-weight:600}.type-badge.standard{background-color:#64748b1a;color:var(--text-secondary);border:1px solid var(--border-color)}.type-badge.vip{background-color:#f59e0b1a;color:var(--primary-color);border:1px solid var(--primary-color)}.type-badge.disabled{background-color:#3b82f61a;color:var(--accent-color);border:1px solid var(--accent-color)}.result-details{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.detail-row{display:flex;justify-content:space-between;font-size:1.125rem}.detail-label{color:var(--text-secondary)}.detail-value{font-weight:600;color:var(--text-primary)}.highlight-row{margin-top:.5rem;padding-top:1rem;border-top:1px dashed var(--border-color)}.amount{color:var(--primary-color);font-size:1.5rem}.location-box{display:flex;align-items:center;gap:1.5rem;background-color:#f59e0b0d;border:1px solid rgba(245,158,11,.3);padding:2rem;border-radius:1rem;margin-bottom:2rem}.location-icon{color:var(--primary-color);animation:bounce 2s infinite}.location-box h4{color:var(--text-secondary);font-size:.875rem;margin-bottom:.25rem}.slot-highlight{font-size:3rem;font-weight:700;color:var(--primary-color);line-height:1}.result-actions{display:flex;justify-content:flex-end}.unpark-btn{width:100%;padding:1rem;font-size:1.125rem;color:var(--error-color);border-color:var(--error-color)}.unpark-btn:hover{background-color:var(--error-color);color:#fff}.history-container{display:flex;flex-direction:column;gap:2rem}.history-header h1{font-size:1.875rem;font-weight:700;margin-bottom:.25rem}.history-header p{color:var(--text-secondary)}.history-stats.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem}.stat-icon{color:var(--primary-color);background-color:#f59e0b1a;width:48px;height:48px;padding:.75rem;border-radius:50%}.stat-icon.warning{color:var(--error-color);background-color:#ef44441a}.stat-info h3{font-size:.875rem;color:var(--text-secondary);font-weight:500;margin-bottom:.25rem}.stat-info .stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1}.history-table-container{overflow-x:auto;padding:0}.history-table{width:100%;border-collapse:collapse;text-align:left}.history-table th,.history-table td{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.history-table th{background-color:var(--surface-hover);color:var(--text-secondary);font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.history-table tbody tr{transition:background-color .2s}.history-table tbody tr:hover{background-color:var(--surface-hover)}.history-table tbody tr:last-child td{border-bottom:none}.fw-600{font-weight:600;color:var(--text-primary)}.time-sub{color:var(--text-secondary);font-size:.875rem;margin-left:.5rem}.cost-cell{color:var(--primary-color)}.type-badge-sm{font-size:.75rem;padding:.25rem .6rem;border-radius:999px;font-weight:600}.type-badge-sm.standard{background-color:#64748b1a;color:var(--text-secondary)}.type-badge-sm.vip{background-color:#f59e0b1a;color:var(--primary-color)}.type-badge-sm.disabled{background-color:#3b82f61a;color:var(--accent-color)}.status-badge{font-size:.75rem;padding:.25rem .6rem;border-radius:999px;font-weight:600}.status-badge.completed{background-color:#10b9811a;color:var(--success-color)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color);padding:2rem}.login-card{width:100%;max-width:450px;padding:3rem 2.5rem;display:flex;flex-direction:column;gap:2rem}.login-header{text-align:center}.login-logo{color:var(--primary-color);margin-bottom:1rem;display:flex;justify-content:center}.login-header h2{font-size:1.875rem;margin-bottom:.5rem}.login-header p{color:var(--text-secondary)}.role-selection{display:flex;gap:1rem;margin-bottom:2rem}.role-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;border-radius:1rem;border:2px solid var(--border-color);background:transparent;color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-family:inherit;font-weight:500}.role-btn:hover{background-color:var(--surface-hover)}.role-btn.active{border-color:var(--primary-color);background-color:#f59e0b0d;box-shadow:0 4px 12px #f59e0b1a}.role-btn.admin.active{border-color:var(--error-color);background-color:#ef44440d;box-shadow:0 4px 12px #ef44441a}.role-btn.admin.active .role-icon{color:var(--error-color)}.role-icon{color:var(--text-secondary)}.role-btn.active .role-icon{color:var(--primary-color)}.login-inputs{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2rem}.login-inputs .form-group{display:flex;flex-direction:column;gap:.5rem}.login-inputs label{font-size:.875rem;font-weight:500}.login-submit-btn{width:100%;padding:1rem;font-size:1.125rem}
