:root{--background-dark: #2B2E3B;--background-darker: #252830;--card-background: #343845;--accent-blue: #688db1;--accent-green: #9cb68f;--accent-red: #e16162;--text-primary: #d1d5db;--text-secondary: #9ca3af;--card-bg: #343845;--border-color: #4B5563;--text-color: #d1d5db;--input-bg: #374151;--primary-color: #688db1;--hover-bg: #414755;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-12: 3rem;--spacing-16: 4rem;--radius-sm: .25rem;--radius: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif}*{margin:0;padding:0;box-sizing:border-box}html{font-family:var(--font-family);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:var(--background-dark);color:var(--text-primary);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:var(--spacing-4)}h1{font-size:2.25rem;color:var(--text-primary)}h2{font-size:1.875rem;color:var(--text-primary)}h3{font-size:1.5rem;color:var(--text-primary)}h4{font-size:1.25rem;color:var(--text-primary)}p{margin-bottom:var(--spacing-4);font-size:1rem;color:var(--text-primary)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--accent-blue)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-4)}.grid{display:grid;gap:var(--spacing-6)}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 768px){.grid-cols-2,.grid-cols-3{grid-template-columns:repeat(1,minmax(0,1fr))}}.card{background-color:var(--card-background);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.1);overflow:hidden;transition:all .3s ease}.card:hover{box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.card-header{padding:var(--spacing-6);border-bottom:1px solid rgba(255,255,255,.1)}.card>*:not(.card-header){padding:var(--spacing-6)}.card>*:not(.card-header):not(:last-child){border-bottom:1px solid rgba(255,255,255,.1)}.card-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-2)}.card-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-3) var(--spacing-6);border-radius:var(--radius-lg);font-size:.875rem;font-weight:500;text-decoration:none;border:none;cursor:pointer;transition:all .3s ease;outline:none;min-height:2.5rem}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--accent-blue);color:#fff}.btn-primary:hover:not(:disabled){background-color:#5a7ca3;transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-secondary{background-color:var(--accent-green);color:#fff}.btn-secondary:hover:not(:disabled){background-color:#8ba380;transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-danger{background-color:var(--accent-red);color:#fff}.btn-danger:hover:not(:disabled){background-color:#d54c4d;transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-success{background-color:var(--accent-green);color:#fff}.btn-success:hover:not(:disabled){background-color:#8ba380;transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-outline{background-color:transparent;border:1px solid var(--accent-blue);color:var(--accent-blue)}.btn-outline:hover:not(:disabled){background-color:var(--accent-blue);color:#fff}.btn-sm{padding:var(--spacing-2) var(--spacing-4);font-size:.75rem;min-height:2rem}.btn-lg{padding:var(--spacing-4) var(--spacing-8);font-size:1rem;min-height:3rem}.form-group{margin-bottom:var(--spacing-4)}.form-label{display:block;margin-bottom:var(--spacing-2);font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-input,.form-textarea{width:100%;padding:var(--spacing-3);border:1px solid rgba(209,213,219,.2);border-radius:var(--radius-lg);background-color:var(--background-darker);color:var(--text-primary);font-size:.875rem;transition:all .3s ease;outline:none}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #688db11a}.form-input:disabled,.form-textarea:disabled{opacity:.6;cursor:not-allowed}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-secondary)}.form-textarea{min-height:120px;resize:vertical}.progress{width:100%;height:var(--spacing-3);background-color:var(--background-darker);border-radius:var(--radius);overflow:hidden;margin-bottom:var(--spacing-4)}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-blue),var(--accent-green));border-radius:var(--radius);transition:width .3s ease;position:relative}.progress-bar:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{text-align:center;margin-top:var(--spacing-2);font-size:.875rem;color:var(--text-secondary)}.status{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius);font-size:.75rem;font-weight:500}.status-success{background-color:#9cb68f33;color:var(--accent-green)}.status-warning{background-color:#e1616233;color:var(--accent-red)}.status-live{background-color:#e1616233;color:var(--accent-red);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.loading{display:inline-block;width:1rem;height:1rem;border:2px solid var(--text-secondary);border-radius:50%;border-top-color:var(--accent-blue);animation:spin 1s ease-in-out infinite}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-2{margin-bottom:var(--spacing-2)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.mb-8{margin-bottom:var(--spacing-8)}.mt-0{margin-top:0}.mt-2{margin-top:var(--spacing-2)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mt-8{margin-top:var(--spacing-8)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--spacing-2)}.gap-4{gap:var(--spacing-4)}.gap-6{gap:var(--spacing-6)}.w-full{width:100%}.min-h-screen{min-height:100vh}.flex-1{flex:1}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.hover\:underline:hover{text-decoration:underline}a{color:var(--text-accent);text-decoration:none;transition:all .3s ease}a:hover{color:#5a7a9d}*:focus{outline:2px solid var(--accent-blue);outline-offset:2px}button:focus,.btn:focus{outline:2px solid var(--accent-blue);outline-offset:2px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--background-darker)}::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.font-weight-500{font-weight:500}.mr-2{margin-right:var(--spacing-2)}.p-3{padding:var(--spacing-3)}.p-4{padding:var(--spacing-4)}.py-8{padding-top:var(--spacing-8);padding-bottom:var(--spacing-8)}.dialog-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-4)}.dialog{background:var(--card-background);border-radius:var(--radius-xl);max-width:900px;max-height:80vh;width:100%;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.1)}.dialog-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-6);border-bottom:1px solid rgba(255,255,255,.1)}.dialog-header h2{margin:0;color:var(--text-primary);font-size:1.5rem}.dialog-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:var(--spacing-2);border-radius:var(--radius);transition:all .3s ease}.dialog-close:hover{background:#ffffff1a;color:var(--text-primary)}.dialog-content{flex:1;overflow-y:auto;padding:var(--spacing-6)}.markdown-content{color:var(--text-primary);line-height:1.6}.markdown-h1{font-size:1.875rem;margin-bottom:var(--spacing-4);color:var(--accent-blue);border-bottom:2px solid var(--accent-blue);padding-bottom:var(--spacing-2);font-weight:700}.markdown-h2{font-size:1.5rem;margin:var(--spacing-6) 0 var(--spacing-3) 0;color:var(--accent-green);font-weight:600}.markdown-h3{font-size:1.25rem;margin:var(--spacing-4) 0 var(--spacing-2) 0;color:var(--text-primary);font-weight:600}.markdown-p{margin-bottom:var(--spacing-3);color:var(--text-primary)}.markdown-p strong{font-weight:600;color:var(--accent-blue)}.markdown-p em{font-style:italic;color:var(--accent-green)}.markdown-p code{background:#ffffff1a;padding:.125rem .25rem;border-radius:var(--radius-sm);font-family:Courier New,monospace;font-size:.875em;color:var(--accent-green)}.markdown-list{margin:var(--spacing-3) 0;padding-left:var(--spacing-6)}.markdown-list li{margin-bottom:var(--spacing-2);color:var(--text-primary);list-style-type:disc}.markdown-list li strong{font-weight:600;color:var(--accent-blue)}.markdown-hr{border:none;height:1px;background:#fff3;margin:var(--spacing-6) 0}.markdown-table{margin:var(--spacing-4) 0;border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.1)}.table-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--spacing-2);padding:var(--spacing-3);border-bottom:1px solid rgba(255,255,255,.1)}.table-row.table-header{font-weight:600;background:#688db133;color:var(--accent-blue)}.table-row:not(.table-header):hover{background:#ffffff0d}.table-cell{padding:var(--spacing-1);color:var(--text-primary);display:flex;align-items:center}.table-cell strong{color:var(--accent-blue);font-weight:600}@media (max-width: 480px){:root{--font-size-base: .875rem;--spacing-card: var(--spacing-3)}.container{padding:0 var(--spacing-2);max-width:100%}body{font-size:var(--font-size-base)}h1{font-size:1.5rem;line-height:1.3}h2{font-size:1.25rem;line-height:1.3}h3{font-size:1.125rem;line-height:1.3}.card{border-radius:var(--radius-lg);margin-bottom:var(--spacing-3)}.card-header{padding:var(--spacing-4)}.card>*:not(.card-header){padding:var(--spacing-4)}.btn{min-height:2.75rem;font-size:.875rem;padding:var(--spacing-3) var(--spacing-5);border-radius:var(--radius)}.btn-sm{min-height:2.25rem;font-size:.75rem;padding:var(--spacing-2) var(--spacing-3)}input[type=checkbox]{width:1.25rem;height:1.25rem;margin:var(--spacing-1)}.mobile-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);border:1px solid var(--text-secondary);background:var(--background-darker)}.mobile-table{width:100%;border-collapse:collapse;min-width:100%}.mobile-table th,.mobile-table td{padding:var(--spacing-3) var(--spacing-2);text-align:left;border-bottom:1px solid rgba(255,255,255,.1)}.mobile-table th{background:var(--card-background);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.025em;position:sticky;top:0;z-index:10}.mobile-table td{font-size:.875rem}.flex.justify-between{flex-direction:column;gap:var(--spacing-3);align-items:stretch}.flex.justify-between.mobile-row{flex-direction:row;align-items:center}.dialog{margin:var(--spacing-2);max-height:85vh;border-radius:var(--radius-lg)}.dialog-header,.dialog-content{padding:var(--spacing-4)}.mobile-button-group{display:flex;flex-direction:column;gap:var(--spacing-2);width:100%}.mobile-button-group .btn{width:100%;justify-content:center}}@media (max-width: 640px){.container{padding:0 var(--spacing-3)}h1{font-size:1.875rem}h2{font-size:1.5rem}.card{padding:var(--spacing-4)}.dialog{margin:var(--spacing-3);max-height:90vh}.dialog-header,.dialog-content{padding:var(--spacing-4)}.table-row{grid-template-columns:1fr;gap:var(--spacing-1)}.flex.justify-between:not(.mobile-row){flex-direction:column;gap:var(--spacing-4)}.flex.justify-between>div:first-child{order:1}}@media (min-width: 768px) and (max-width: 1024px){.container{padding:0 var(--spacing-4)}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1200px){.container{max-width:1200px;padding:0 var(--spacing-6)}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.btn,.card{border-width:.5px}}@media (max-width: 896px) and (orientation: landscape){.dialog{max-height:95vh;margin:var(--spacing-1)}.dialog-content{padding:var(--spacing-3)}}@media (max-width: 414px){.container{padding:0 var(--spacing-2)}.btn{min-height:3rem;font-weight:600}.gap-2{gap:var(--spacing-1)}.gap-4{gap:var(--spacing-2)}.gap-6{gap:var(--spacing-3)}}@media (max-width: 480px) and (min-height: 800px){.container{padding:0 var(--spacing-3)}.dialog{max-height:80vh}.btn{min-height:3.25rem;font-size:1rem}.card{margin-bottom:.75rem}.card-header{padding:.75rem}.card>*:not(.card-header){padding:.75rem}h1{margin-top:.5rem!important;font-size:1.5rem!important}button[style*=fontSize]{font-size:.75rem!important;padding:.4rem .6rem!important}.mb-6{margin-bottom:var(--spacing-4)!important}.mb-4{margin-bottom:var(--spacing-3)!important}}@media (max-width: 640px){.mobile-button-group{display:flex!important}.mobile-button-group+.flex{display:none!important}}@media (min-width: 641px){.mobile-button-group{display:none!important}.mobile-button-group+.flex{display:flex!important}}@media (max-width: 640px){*:focus{outline:3px solid var(--accent-blue);outline-offset:2px}.text-secondary{color:#b3b8c2}}@media (max-width: 640px) and (prefers-color-scheme: dark){:root{--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .6), 0 4px 6px -4px rgba(0, 0, 0, .4)}.card{box-shadow:var(--shadow-lg)}}.backdrop-blur-sm{backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.backdrop-blur{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.backdrop-blur-md{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.backdrop-blur-lg{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.backdrop-blur-xl{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}@media (prefers-reduced-motion: reduce){.backdrop-blur-sm,.backdrop-blur,.backdrop-blur-md,.backdrop-blur-lg,.backdrop-blur-xl{backdrop-filter:none;-webkit-backdrop-filter:none}}.theme-dark{--transition-smooth: all .3s ease-in-out}.theme-light{--transition-smooth: all .3s ease-in-out;background:var(--background-dark)!important;color:var(--text-primary)!important}.theme-light body{background:linear-gradient(135deg,#f8fafc,#e2e8f0);color:var(--text-primary)}.theme-light .card,.theme-light [style*="background: var(--card-bg)"],.theme-light [style*="background-color: var(--card-bg)"]{background:#fff!important;border:1px solid #E5E7EB!important;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f!important}.theme-light button{transition:var(--transition-smooth)}.theme-light button:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.theme-light input,.theme-light select,.theme-light textarea{background:var(--input-bg)!important;border:1px solid #D1D5DB!important;color:var(--text-primary)!important}.theme-light input:focus,.theme-light select:focus,.theme-light textarea:focus{border-color:var(--primary-color)!important;box-shadow:0 0 0 3px #3b82f61a!important}.theme-xd{--transition-smooth: all .3s ease-in-out;--font-xd: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}.theme-xd body{background:#020617;color:#f8fafc;font-family:var(--font-xd);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.theme-xd .min-h-screen{background:radial-gradient(ellipse at top center,rgba(99,102,241,.08) 0%,transparent 60%),#020617}.theme-xd .card,.theme-xd [style*="background: var(--card-bg)"],.theme-xd [style*="background-color: var(--card-bg)"]{background:#1e293b80!important;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(51,65,85,.5)!important;border-radius:12px!important;box-shadow:0 4px 24px #0003!important;transition:all .3s ease!important}.theme-xd .card:hover,.theme-xd [style*="background: var(--card-bg)"]:hover{border-color:#6366f166!important;box-shadow:0 8px 32px #6366f114,0 4px 16px #0000004d!important}.theme-xd h1{font-weight:700;letter-spacing:-.02em}.theme-xd .action-bar__title{background:linear-gradient(135deg,#818cf8,#8b5cf6,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;letter-spacing:-.02em}.theme-xd .btn-primary,.theme-xd .action-bar__login-button{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;border:none!important;color:#fff!important;font-weight:600;box-shadow:0 2px 12px #6366f14d;transition:all .3s ease!important}.theme-xd .btn-primary:hover,.theme-xd .action-bar__login-button:hover{box-shadow:0 4px 20px #8b5cf680!important;transform:translateY(-1px) scale(1.02)}.theme-xd button{transition:all .3s ease}.theme-xd .action-bar{background:#0f172ad9!important;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(30,41,59,.8)}.theme-xd .side-drawer{background:#0f172a!important;border-right:1px solid rgba(51,65,85,.5)}.theme-xd .side-drawer__header{background:linear-gradient(135deg,#6366f114,#8b5cf60d);border-bottom-color:#33415580}.theme-xd .side-drawer__avatar{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important}.theme-xd .side-drawer__nav-item:hover{background-color:#6366f114!important}.theme-xd input,.theme-xd select,.theme-xd textarea{background:#1e293b!important;border:1px solid rgba(51,65,85,.7)!important;color:#f8fafc!important;border-radius:8px!important;transition:all .2s ease!important}.theme-xd input:focus,.theme-xd select:focus,.theme-xd textarea:focus{border-color:#6366f1!important;box-shadow:0 0 0 3px #6366f126!important;outline:none}.theme-xd a{color:#818cf8;transition:color .2s ease}.theme-xd a:hover{color:#6366f1}.theme-xd ::-webkit-scrollbar{width:6px;background:#020617}.theme-xd ::-webkit-scrollbar-track{background:#020617}.theme-xd ::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:3px}.theme-xd ::-webkit-scrollbar-thumb:hover{background:#6366f180}.theme-xd .status-live{background:#6366f126;color:#818cf8;border:1px solid rgba(99,102,241,.3)}.theme-xd .app-footer{background:#0f172ae6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(51,65,85,.5)}.theme-xd .dialog-overlay{background:#020617d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.theme-xd .dialog{background:#0f172a!important;border:1px solid rgba(51,65,85,.5)!important;box-shadow:0 24px 48px #00000080,0 0 0 1px #6366f11a!important}.theme-xd .admin-sidebar{background:#0f172a;border-right-color:#33415580}.theme-xd .admin-sidebar__item--active{background:#6366f11f;color:#818cf8}.theme-xd .admin-chart-card{background:#1e293b80;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-color:#33415580}.theme-xd .admin-chart-card:hover{border-color:#6366f14d}.theme-xd .admin-metrics-card{background:#1e293b80;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-color:#33415580}.theme-xd .admin-metrics-card:hover{border-color:#6366f166;box-shadow:0 4px 16px #6366f114}.theme-xd .admin-btn--primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none}.theme-xd .admin-time-range__btn--active{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.theme-xd .admin-chip--active{background:#6366f126;border-color:#6366f1;color:#818cf8}*{transition:var(--transition-smooth)}.no-transition,.no-transition *{transition:none!important}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}.dialog__backdrop{position:fixed;inset:0;z-index:2000;background-color:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn .2s ease}.dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2100;background-color:var(--card-background);border-radius:var(--radius-xl);box-shadow:0 20px 25px -5px #0000004d,0 10px 10px -5px #0003;max-width:90vw;max-height:90vh;width:500px;display:flex;flex-direction:column;animation:scaleIn .2s ease;outline:none}@keyframes scaleIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.dialog__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.dialog__title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.2}.dialog__close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;color:var(--text-secondary);font-size:2rem;line-height:1;cursor:pointer;border-radius:var(--radius);transition:all .2s ease;flex-shrink:0;margin-left:1rem}.dialog__close-button:hover{background-color:#ffffff1a;color:var(--text-primary)}.dialog__close-button:active{background-color:#ffffff26;transform:scale(.95)}.dialog__content{padding:1.5rem;overflow-y:auto;flex:1;min-height:0}.dialog__content::-webkit-scrollbar{width:8px}.dialog__content::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.dialog__content::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.dialog__content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media (max-width: 480px){.dialog--fullscreen-mobile{width:100vw;max-width:100vw;height:100vh;max-height:100vh;inset:0;transform:none;border-radius:0}.dialog--fullscreen-mobile .dialog__header,.dialog--fullscreen-mobile .dialog__content{padding:1rem}}@media (min-width: 480px) and (max-width: 768px){.dialog{width:85vw;max-width:600px}.dialog__header,.dialog__content{padding:1.25rem}}@media (min-width: 768px){.dialog{width:600px}}.dialog:focus{outline:2px solid var(--accent-blue);outline-offset:-2px}.dialog__close-button:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}@media (prefers-contrast: high){.dialog{border:2px solid var(--text-primary)}.dialog__header{border-bottom-width:2px}}@media (prefers-reduced-motion: reduce){.dialog,.dialog__backdrop{animation:none}.dialog__close-button{transition:none}}.dialog *{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) rgba(255,255,255,.05)}body.dialog-open{overflow:hidden}.login-form{width:100%;animation:fadeIn .3s ease}.login-header{text-align:center;margin-bottom:2rem}.login-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:linear-gradient(135deg,var(--accent-blue) 0%,#5a8fd8 100%);border-radius:50%;margin:0 auto 1rem;box-shadow:0 4px 12px #688db14d;color:#fff}.login-form h3{margin:0 0 .5rem;color:var(--text-primary);font-size:1.75rem;font-weight:700}.login-subtitle{margin:0;color:var(--text-secondary);font-size:.875rem;opacity:.8}.input-wrapper:focus-within .input-icon{color:var(--accent-blue);opacity:1}.form-group input:focus{outline:none;border-color:var(--accent-blue);background:var(--background);box-shadow:0 0 0 4px #688db11a}.login-btn,.cancel-btn{width:100%;padding:12px 24px;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-btn.primary{background:linear-gradient(135deg,var(--accent-blue) 0%,#5a8fd8 100%);color:#fff;box-shadow:0 2px 8px #688db14d;margin-bottom:.75rem}.login-btn.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #688db166}.login-btn.primary:active:not(:disabled){transform:translateY(0)}.login-btn.primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.link-btn{background:none;border:none;color:var(--accent-blue);cursor:pointer;font-size:.875rem;font-weight:600;padding:0;transition:all .2s ease}.link-btn:hover{color:#5a8fd8;text-decoration:underline}@media (max-width: 480px){.login-form h3{font-size:1.5rem}.login-icon{width:56px;height:56px}.form-group input{padding:11px 12px 11px 42px;font-size:16px}.login-btn,.cancel-btn{padding:11px 20px;font-size:.875rem}}.login-btn:focus-visible,.cancel-btn:focus-visible,.link-btn:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}@media (prefers-reduced-motion: reduce){.login-form,.error-message,.login-btn,.cancel-btn,.input-icon{animation:none;transition:none}}.register-form{width:100%;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.register-header{text-align:center;margin-bottom:2rem}.register-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:linear-gradient(135deg,var(--accent-green) 0%,#66bb6a 100%);border-radius:50%;margin:0 auto 1rem;box-shadow:0 4px 12px #66bb6a4d;color:#fff}.register-form h3{margin:0 0 .5rem;color:var(--text-primary);font-size:1.75rem;font-weight:700}.register-subtitle{margin:0;color:var(--text-secondary);font-size:.875rem;opacity:.8}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:600;font-size:.875rem}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:14px;color:var(--text-secondary);opacity:.6;pointer-events:none;transition:all .2s ease}.input-wrapper:focus-within .input-icon{color:var(--accent-green);opacity:1}.form-group input{width:100%;padding:12px 14px 12px 46px;border:2px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-primary);font-size:.9375rem;box-sizing:border-box;transition:all .2s ease}.form-group input::placeholder{color:var(--text-secondary);opacity:.5}.form-group input:focus{outline:none;border-color:var(--accent-green);background:var(--background);box-shadow:0 0 0 4px #66bb6a1a}.form-group input:disabled{opacity:.6;cursor:not-allowed;background:var(--background-darker)}.password-hint{display:block;color:var(--text-secondary);font-size:.75rem;margin-top:.375rem;opacity:.7}.error-message{display:flex;align-items:center;gap:.75rem;background:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:8px;padding:12px 16px;margin-bottom:1.5rem;color:#f44336;font-size:.875rem;animation:shake .3s ease}.error-message svg{flex-shrink:0}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.success-message{display:flex;align-items:center;gap:.75rem;background:#4caf501a;border:1px solid rgba(76,175,80,.3);border-radius:8px;padding:12px 16px;margin-bottom:1.5rem;color:#4caf50;font-size:.875rem;animation:slideIn .3s ease}.success-message svg{flex-shrink:0}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.register-btn,.cancel-btn{width:100%;padding:12px 24px;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.register-btn.primary{background:linear-gradient(135deg,var(--accent-green) 0%,#66bb6a 100%);color:#fff;box-shadow:0 2px 8px #66bb6a4d;margin-bottom:.75rem}.register-btn.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #66bb6a66}.register-btn.primary:active:not(:disabled){transform:translateY(0)}.register-btn.primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.cancel-btn{background:transparent;color:var(--text-secondary);border:2px solid var(--border-color)}.cancel-btn:hover:not(:disabled){background:var(--hover-bg);border-color:var(--text-secondary);color:var(--text-primary)}.divider{position:relative;text-align:center;margin:1.5rem 0}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:calc(50% - 60px);height:1px;background:var(--border-color)}.divider:before{left:0}.divider:after{right:0}.divider span{display:inline-block;padding:0 1rem;background:var(--background);color:var(--text-secondary);font-size:.8125rem;font-weight:500}.google-login-wrapper{display:flex;justify-content:center;margin-bottom:1.5rem}.auth-switch{text-align:center;padding-top:1.25rem;border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.875rem}.link-btn{background:none;border:none;color:var(--accent-green);cursor:pointer;font-size:.875rem;font-weight:600;padding:0;transition:all .2s ease}.link-btn:hover{color:#66bb6a;text-decoration:underline}@media (max-width: 480px){.register-form h3{font-size:1.5rem}.register-icon{width:56px;height:56px}.form-group input{padding:11px 12px 11px 42px;font-size:16px}.register-btn,.cancel-btn{padding:11px 20px;font-size:.875rem}}.register-btn:focus-visible,.cancel-btn:focus-visible,.link-btn:focus-visible{outline:2px solid var(--accent-green);outline-offset:2px}@media (prefers-reduced-motion: reduce){.register-form,.error-message,.success-message,.register-btn,.cancel-btn,.input-icon{animation:none;transition:none}}.auth-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.auth-dialog-content{position:relative;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d;border-radius:8px;animation:dialogFadeIn .2s ease-out}@keyframes dialogFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.auth-dialog-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:24px;line-height:1;color:var(--text-color);cursor:pointer;z-index:1001;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.auth-dialog-close:hover{background:var(--hover-bg)}@media (max-width: 480px){.auth-dialog-overlay{padding:10px}.auth-dialog-content{width:100%;max-width:none;margin:0}}.user-profile{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:24px;max-width:600px;width:100%;height:600px;max-height:80vh;display:flex;flex-direction:column}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.profile-header h3{margin:0;color:var(--text-color);font-size:1.5rem}.logout-btn{padding:8px 16px;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease}.logout-btn:hover{background:#c82333}.profile-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border-color)}.profile-tabs button{padding:10px 16px;background:none;border:none;border-bottom:3px solid transparent;color:var(--text-color);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.profile-tabs button:hover{background:var(--hover-bg)}.profile-tabs button.active{border-bottom-color:var(--primary-color);color:var(--primary-color)}.error-message{background:#fee;border:1px solid #fcc;border-radius:4px;padding:10px;margin-bottom:16px;color:#c33;font-size:14px}.success-message{background:#efe;border:1px solid #cfc;border-radius:4px;padding:10px;margin-bottom:16px;color:#363;font-size:14px}.profile-content{flex:1;overflow-y:auto;min-height:0}.profile-info{display:flex;flex-direction:column;gap:16px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color)}.info-item:last-child{border-bottom:none}.info-item label{font-weight:600;color:var(--text-color)}.info-item span{color:var(--text-color)}.filters-section h4{margin:0 0 16px;color:var(--text-color);font-size:1.1rem}.add-filter-form{background:var(--hover-bg);border-radius:6px;padding:16px;margin-bottom:24px}.filter-inputs{display:flex;gap:10px;align-items:stretch}.filter-inputs select,.filter-inputs input{flex:1;padding:8px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-color);font-size:14px}.filter-inputs button{padding:8px 16px;background:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;white-space:nowrap;transition:background-color .2s ease}.filter-inputs button:hover:not(:disabled){background:#3a7bc8}.filter-inputs button:disabled{opacity:.6;cursor:not-allowed}.filters-list{margin-top:20px}.no-filters{text-align:center;color:var(--text-color);opacity:.7;font-style:italic;padding:20px}.filter-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid var(--border-color);border-radius:4px;margin-bottom:8px;background:var(--card-bg);transition:opacity .2s ease}.filter-item.inactive{opacity:.6;background:var(--hover-bg)}.filter-info{flex:1;display:flex;flex-direction:column;gap:4px}.filter-type{font-weight:600;color:var(--text-color);font-size:14px}.filter-value{color:var(--primary-color);font-size:13px;font-family:monospace}.filter-actions{display:flex;gap:8px}.toggle-btn{padding:6px 12px;border:1px solid;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s ease}.toggle-btn.active{background:#28a745;border-color:#28a745;color:#fff}.toggle-btn.inactive{background:#6c757d;border-color:#6c757d;color:#fff}.delete-btn{padding:6px 12px;background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;transition:background-color .2s ease}.delete-btn:hover{background:#c82333}@media (max-width: 600px){.filter-inputs{flex-direction:column}.filter-item{flex-direction:column;gap:12px;align-items:stretch}.filter-actions{justify-content:center}}.themes-section{padding:1rem}.themes-description{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem}.theme-options{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}.theme-option{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--hover-bg);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .3s ease}.theme-option:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.theme-option.selected{border-color:var(--primary-color);background:rgba(var(--primary-color-rgb, 104, 141, 177),.1);box-shadow:0 0 0 1px var(--primary-color)}.theme-preview{flex-shrink:0}.preview-circle{width:50px;height:50px;border-radius:50%;border:2px solid var(--border-color);position:relative;overflow:hidden}.theme-dark .preview-circle{background:linear-gradient(45deg,#688db1,#9cb68f)}.theme-light .preview-circle{background:linear-gradient(45deg,#3b82f6,#10b981);box-shadow:0 2px 8px #0000001a}.theme-newspaper .preview-circle{background:linear-gradient(45deg,#f5f1e8,#2c2c2c,#f5f1e8);background-size:200% 200%;position:relative}.theme-newspaper .preview-circle:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.1) 2px,rgba(0,0,0,.1) 4px);pointer-events:none}.theme-berlin .preview-circle{background:linear-gradient(45deg,#f0c040,#7ec8a0);border-color:#363b4e}.theme-info{flex:1}.theme-info h5{margin:0 0 .5rem;color:var(--text-primary);font-size:1.1rem}.theme-info p{margin:0;color:var(--text-secondary);font-size:.9rem}.selected-indicator{color:var(--primary-color);font-weight:700;font-size:.9rem;margin-top:.5rem;display:block}.theme-note{background:var(--input-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem;margin-top:1rem}.theme-note p{margin:0;font-size:.9rem;color:var(--text-secondary)}.language-section{padding:1rem}.language-description{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem}.language-options{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}.language-option{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--hover-bg);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .3s ease}.language-option:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.language-option.selected{border-color:var(--primary-color);background:rgba(var(--primary-color-rgb, 104, 141, 177),.1);box-shadow:0 0 0 1px var(--primary-color)}.language-info{flex:1}.language-info h5{margin:0 0 .5rem;color:var(--text-primary);font-size:1.1rem}.language-info p{margin:0;color:var(--text-secondary);font-size:.9rem}.language-note{background:var(--input-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem;margin-top:1rem}.language-note p{margin:0;font-size:.9rem;color:var(--text-secondary)}@media (min-width: 768px){.theme-options{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.theme-option{flex-direction:column;text-align:center;padding:1.5rem}.theme-info{margin-top:1rem}.preview-circle{width:80px;height:80px}.language-options{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}.user-locations-container{background:#1a1a1a;border-radius:12px;padding:24px;width:100%;max-width:600px;margin:0 auto;max-height:80vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.user-locations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #333}.user-locations-header h2{display:flex;align-items:center;gap:12px;color:#fff;font-size:24px;margin:0}.close-button{background:transparent;border:none;color:#999;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s}.close-button:hover{background:#333;color:#fff}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px;border-radius:8px;margin-bottom:16px;animation:shake .3s ease-out}.success-message{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#22c55e;padding:12px;border-radius:8px;margin-bottom:16px;animation:slideDown .3s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.saved-locations-section,.add-locations-section{margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{color:#fff;font-size:18px;margin:0}.check-button{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;transition:all .2s}.check-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.check-button:disabled{opacity:.5;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 24px;color:#666}.empty-state svg{color:#444;margin-bottom:16px}.empty-state p{font-size:16px;margin-bottom:8px;color:#999}.empty-state span{font-size:14px;color:#666}.locations-list{display:flex;flex-direction:column;gap:8px}.location-item{display:flex;align-items:center;gap:12px;background:#2a2a2a;padding:12px;border-radius:8px;transition:all .2s;cursor:move}.location-item:hover{background:#333}.location-item.dragging{opacity:.5}.drag-handle{color:#666;cursor:grab}.drag-handle:active{cursor:grabbing}.location-info{flex:1}.location-name{color:#fff;font-size:14px;font-weight:500}.location-address{color:#888;font-size:12px;margin-top:4px}.remove-button{background:transparent;border:none;color:#666;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s}.remove-button:hover{background:#ef44441a;color:#ef4444}.toggle-section-button{display:flex;align-items:center;gap:8px;background:transparent;border:none;color:#fff;cursor:pointer;padding:0;transition:all .2s}.toggle-section-button:hover{color:#667eea}.search-bar{display:flex;align-items:center;gap:12px;background:#2a2a2a;padding:12px;border-radius:8px;margin-bottom:16px}.search-bar svg{color:#666}.search-bar input{flex:1;background:transparent;border:none;color:#fff;font-size:14px;outline:none}.search-bar input::placeholder{color:#666}.available-locations{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.available-location-item{display:flex;justify-content:space-between;align-items:center;background:#2a2a2a;padding:12px;border-radius:8px;transition:all .2s}.available-location-item:hover{background:#333}.add-button{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#22c55e;padding:8px;border-radius:6px;cursor:pointer;transition:all .2s}.add-button:hover{background:#22c55e33;transform:scale(1.1)}.empty-search{text-align:center;padding:24px;color:#666;font-size:14px}.user-locations-container::-webkit-scrollbar,.available-locations::-webkit-scrollbar{width:8px}.user-locations-container::-webkit-scrollbar-track,.available-locations::-webkit-scrollbar-track{background:#1a1a1a}.user-locations-container::-webkit-scrollbar-thumb,.available-locations::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.user-locations-container::-webkit-scrollbar-thumb:hover,.available-locations::-webkit-scrollbar-thumb:hover{background:#555}.action-bar{position:fixed;top:0;left:0;right:0;z-index:1000;background-color:var(--background-darker);border-bottom:1px solid rgba(255,255,255,.1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.action-bar__container{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:.75rem 1rem;height:60px}.action-bar__menu-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background:transparent;border:none;cursor:pointer;border-radius:8px;transition:background-color .2s ease}.action-bar__menu-button:hover{background-color:#ffffff1a}.action-bar__menu-button:active{background-color:#ffffff26}.action-bar__hamburger{display:flex;flex-direction:column;justify-content:space-between;width:24px;height:18px}.action-bar__hamburger span{display:block;width:100%;height:2px;background-color:var(--text-primary);border-radius:2px;transition:all .3s ease}.action-bar__brand{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:center}.action-bar__logo{font-size:1.5rem;line-height:1}.action-bar__title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.01em}.action-bar__login-button{min-width:80px;padding:.5rem 1rem;font-size:.9rem;height:44px}.action-bar__login-text{display:inline}.action-bar__spacer{width:44px}@media (max-width: 480px){.action-bar__container{padding:.5rem .75rem;height:56px}.action-bar__title{font-size:1.1rem}.action-bar__logo{font-size:1.3rem}.action-bar__login-button{min-width:70px;padding:.4rem .8rem;font-size:.85rem}.action-bar__login-text{display:inline}.action-bar__menu-button{width:40px;height:40px}.action-bar__spacer{width:40px}}@media (min-width: 480px) and (max-width: 768px){.action-bar__title{font-size:1.2rem}}@media (min-width: 1200px){.action-bar__container{padding:.75rem 2rem}.action-bar__title{font-size:1.35rem}}.action-bar__menu-button:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.action-bar__login-button:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}@media (prefers-contrast: high){.action-bar{border-bottom-width:2px}.action-bar__hamburger span{height:3px}}@media (prefers-reduced-motion: reduce){.action-bar__menu-button,.action-bar__hamburger span{transition:none}}.side-drawer__backdrop{position:fixed;inset:0;z-index:1100;background-color:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.side-drawer{position:fixed;top:0;left:0;bottom:0;z-index:1200;width:280px;background-color:var(--background-darker);box-shadow:4px 0 24px #0000004d;animation:slideIn .3s ease;overflow-y:auto;overflow-x:hidden}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.side-drawer__content{display:flex;flex-direction:column;height:100%;padding-top:60px}.side-drawer__header{display:flex;align-items:center;gap:1rem;padding:1.5rem 1rem;background:linear-gradient(135deg,#688db11a,#688db10d);border-bottom:1px solid rgba(255,255,255,.1)}.side-drawer__avatar{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--accent-blue);color:#fff;border-radius:50%;font-size:1.25rem;font-weight:600;flex-shrink:0}.side-drawer__user-info{display:flex;flex-direction:column;gap:.25rem;min-width:0;flex:1}.side-drawer__user-name{font-size:1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-drawer__user-email{font-size:.85rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-drawer__nav{flex:1;padding:1rem 0;overflow-y:auto}.side-drawer__nav-item{display:flex;align-items:center;gap:1rem;width:100%;padding:.875rem 1rem;background:transparent;border:none;cursor:pointer;text-align:left;transition:background-color .2s ease;color:var(--text-primary);font-size:.95rem}.side-drawer__nav-item:hover{background-color:#ffffff0d}.side-drawer__nav-item:active{background-color:#ffffff1a}.side-drawer__nav-icon{font-size:1.25rem;line-height:1;flex-shrink:0}.side-drawer__nav-label{font-size:.95rem;font-weight:500}.side-drawer__divider{height:1px;margin:.5rem 1rem;background-color:#ffffff1a}.side-drawer__theme-section{padding:1rem 1rem .5rem}.side-drawer__section-title{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.side-drawer__social-section{padding:1rem 1rem .5rem}.side-drawer__social-link{text-decoration:none;position:relative}.side-drawer__social-link:hover{background-color:#688db11a}.side-drawer__social-link .side-drawer__nav-icon svg{display:block;color:var(--text-primary);transition:color .2s ease}.side-drawer__social-link:hover .side-drawer__nav-icon svg{color:var(--accent-blue)}.side-drawer__external-icon{margin-left:auto;font-size:1rem;color:var(--text-secondary);opacity:.6;transition:opacity .2s ease}.side-drawer__social-link:hover .side-drawer__external-icon{opacity:1;color:var(--accent-blue)}.side-drawer__footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1);margin-top:auto}.side-drawer__logout-button{display:flex;align-items:center;gap:1rem;width:100%;padding:.875rem 1rem;background:transparent;border:1px solid var(--accent-red);border-radius:8px;cursor:pointer;text-align:left;transition:all .2s ease;color:var(--accent-red);font-size:.95rem;font-weight:500}.side-drawer__logout-button:hover{background-color:#e161621a;border-color:var(--accent-red)}.side-drawer__logout-button:active{background-color:#e1616226;transform:scale(.98)}.side-drawer__version{text-align:center;font-size:.75rem;color:var(--text-secondary);opacity:.5;margin-top:.75rem}@media (max-width: 480px){.side-drawer{width:85%;max-width:320px}.side-drawer__content{padding-top:56px}.side-drawer__header{padding:1rem .875rem}.side-drawer__nav-item{padding:.75rem .875rem}.side-drawer__footer{padding:.875rem}}@media (min-width: 480px) and (max-width: 768px){.side-drawer{width:320px}}@media (min-width: 768px){.side-drawer{width:360px}}.side-drawer__nav::-webkit-scrollbar{width:8px}.side-drawer__nav::-webkit-scrollbar-track{background:transparent}.side-drawer__nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.side-drawer__nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.side-drawer__nav-item:focus-visible{outline:2px solid var(--accent-blue);outline-offset:-2px}.side-drawer__logout-button:focus-visible{outline:2px solid var(--accent-red);outline-offset:2px}@media (prefers-contrast: high){.side-drawer{border-left:2px solid var(--text-primary)}.side-drawer__divider{height:2px}}@media (prefers-reduced-motion: reduce){.side-drawer,.side-drawer__backdrop{animation:none}.side-drawer__nav-item,.side-drawer__logout-button{transition:none}}.admin-layout{display:flex;min-height:100vh;background:var(--background);color:var(--text-color)}.admin-content{flex:1;padding:2rem;overflow-y:auto;min-width:0}.admin-sidebar{width:220px;background:var(--card-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.admin-sidebar__header{padding:1.25rem 1rem;border-bottom:1px solid var(--border-color)}.admin-sidebar__back{font-size:.8rem;color:var(--text-secondary);text-decoration:none;display:block;margin-bottom:.5rem}.admin-sidebar__back:hover{color:var(--accent-blue)}.admin-sidebar__title{font-size:1.25rem;font-weight:700;margin:0;color:var(--text-color)}.admin-sidebar__nav{padding:.5rem;flex:1}.admin-sidebar__item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.65rem .75rem;border:none;background:transparent;color:var(--text-secondary);font-size:.9rem;cursor:pointer;border-radius:8px;transition:all .15s ease;text-align:left}.admin-sidebar__item:hover{background:var(--hover-bg);color:var(--text-color)}.admin-sidebar__item--active{background:#688db126;color:var(--accent-blue);font-weight:500}.admin-sidebar__icon{font-size:1.1rem;width:1.5rem;text-align:center}.admin-tabs-mobile{display:none}.admin-page-title{font-size:1.5rem;font-weight:700;margin:0 0 1.5rem;color:var(--text-color)}.admin-page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.admin-metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.admin-metrics-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;transition:border-color .2s ease}.admin-metrics-card:hover{border-color:var(--accent-blue)}.admin-metrics-card__header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.admin-metrics-card__icon{font-size:1.25rem}.admin-metrics-card__title{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.admin-metrics-card__value{font-size:1.75rem;font-weight:700;line-height:1.2;margin-bottom:.25rem}.admin-metrics-card__footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.admin-metrics-card__subtitle{font-size:.8rem;color:var(--text-secondary)}.admin-metrics-card__trend{font-size:.8rem;font-weight:600}.admin-charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem;margin-bottom:1.5rem}.admin-chart-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.admin-chart-title{font-size:1rem;font-weight:600;margin:0 0 1rem;color:var(--text-color)}.admin-chart-empty{text-align:center;padding:2rem;color:var(--text-secondary);background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;margin-bottom:1.5rem}.admin-heatmap-legend{display:flex;align-items:center;gap:.5rem;justify-content:center;margin-top:.75rem;font-size:.75rem;color:var(--text-secondary)}.admin-heatmap-legend__bar{width:120px;height:8px;border-radius:4px;background:linear-gradient(to right,#22c55e,#84cc16,#eab308,#f97316,#ef4444)}.admin-table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid var(--border-color)}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th{padding:.75rem 1rem;text-align:left;background:var(--hover-bg);color:var(--text-secondary);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-bottom:1px solid var(--border-color)}.admin-table td{padding:.65rem 1rem;border-bottom:1px solid var(--border-color);color:var(--text-color)}.admin-table tbody tr:hover{background:var(--hover-bg)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-stats-row{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.5rem}.admin-stat{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1rem 1.5rem;text-align:center;min-width:120px}.admin-stat__label{display:block;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.25rem}.admin-stat__value{display:block;font-size:1.5rem;font-weight:700;color:var(--text-color)}.admin-page-header__controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.admin-location-header{margin-bottom:1.5rem}.admin-location-header h2{margin:0 0 .25rem;font-size:1.25rem}.admin-location-dropdown{position:relative;min-width:260px;max-width:400px}.admin-location-dropdown__trigger{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg, var(--card-bg));color:var(--text-color);font-size:.85rem;cursor:pointer;text-align:left;transition:border-color .15s ease}.admin-location-dropdown__trigger:hover{border-color:var(--accent-blue)}.admin-location-dropdown__selected{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.admin-location-dropdown__selected-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-location-dropdown__selected-addr{font-size:.75rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-location-dropdown__occ{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;padding:.15rem .5rem;background:var(--hover-bg);border-radius:12px}.admin-location-dropdown__placeholder{flex:1;color:var(--text-secondary)}.admin-location-dropdown__chevron{font-size:.6rem;color:var(--text-secondary);margin-left:.25rem}.admin-location-dropdown__menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--input-bg, var(--card-bg));border:1px solid var(--border-color);border-radius:10px;box-shadow:0 8px 24px #00000040;z-index:100;overflow:hidden}.admin-location-dropdown__search{width:100%;padding:.6rem .75rem;border:none;border-bottom:1px solid var(--border-color);background:var(--input-bg);color:var(--text-color);font-size:.85rem;outline:none;box-sizing:border-box}.admin-location-dropdown__search:focus{background:var(--hover-bg)}.admin-location-dropdown__list{max-height:360px;overflow-y:auto}.admin-location-dropdown__item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;padding:.5rem .75rem;border:none;background:transparent;color:var(--text-color);font-size:.85rem;cursor:pointer;text-align:left;transition:background .1s ease}.admin-location-dropdown__item:hover{background:var(--hover-bg)}.admin-location-dropdown__item--active{background:#688db126;color:var(--accent-blue)}.admin-location-dropdown__item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.admin-location-dropdown__item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.admin-location-dropdown__item-addr{font-size:.75rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-location-dropdown__item-occ{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.admin-location-dropdown__empty{padding:1.25rem;text-align:center;color:var(--text-secondary);font-size:.85rem}.admin-opening-hours{display:grid;gap:.25rem}.admin-opening-hours__row{display:flex;align-items:center;gap:1rem;padding:.35rem 0}.admin-opening-hours__day{width:30px;font-weight:600;color:var(--text-secondary);font-size:.85rem}.admin-opening-hours__time{font-size:.85rem;color:var(--text-color)}.admin-btn{padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-color);border-radius:8px;cursor:pointer;font-size:.85rem;transition:all .15s ease}.admin-btn:hover:not(:disabled){background:var(--hover-bg)}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn--primary{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.admin-btn--primary:hover:not(:disabled){opacity:.9;background:var(--accent-blue)}.admin-btn--sm{padding:.3rem .6rem;font-size:.8rem}.admin-badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:500;background:var(--hover-bg);color:var(--text-secondary);margin-right:.5rem}.admin-badge--success{background:#22c55e26;color:#22c55e}.admin-badge--warning{background:#f9731626;color:#f97316}.admin-toggle{width:32px;height:32px;border:1px solid var(--border-color);border-radius:6px;background:transparent;cursor:pointer;font-size:.9rem;color:#ef4444;transition:all .15s ease}.admin-toggle--active{color:var(--accent-green);border-color:var(--accent-green)}.admin-status-dot{display:inline-block;width:10px;height:10px;border-radius:50%}.admin-status-dot--green{background:#22c55e}.admin-status-dot--yellow{background:#eab308}.admin-status-dot--red{background:#ef4444}.admin-filters-row{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.admin-search-input{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-color);font-size:.85rem;min-width:200px;outline:none}.admin-search-input:focus{border-color:var(--accent-blue)}.admin-select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-color);font-size:.85rem;outline:none;cursor:pointer}.admin-select--inline{padding:.25rem .4rem;font-size:.8rem}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}.admin-time-range{display:flex;gap:.25rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:.2rem}.admin-time-range__btn{padding:.35rem .75rem;border:none;background:transparent;color:var(--text-secondary);font-size:.8rem;cursor:pointer;border-radius:6px;transition:all .15s ease}.admin-time-range__btn:hover{color:var(--text-color)}.admin-time-range__btn--active{background:var(--accent-blue);color:#fff}.admin-compare-selector{margin-bottom:1.5rem}.admin-compare-search{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-color);font-size:.85rem;outline:none;box-sizing:border-box;margin-bottom:.75rem}.admin-compare-search:focus{border-color:var(--accent-blue)}.admin-compare-chips-wrapper{display:flex;flex-wrap:wrap;gap:.4rem;max-height:200px;overflow-y:auto;margin-bottom:.75rem;padding:.25rem 0}.admin-compare-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem}.admin-compare-count{font-size:.8rem;color:var(--text-secondary)}.admin-compare-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.admin-chip{padding:.3rem .7rem;border:1px solid var(--border-color);border-radius:20px;background:transparent;color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .15s ease}.admin-chip:hover{border-color:var(--accent-blue);color:var(--text-color)}.admin-chip--active{background:#688db133;border-color:var(--accent-blue);color:var(--accent-blue)}.admin-modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.admin-modal{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column}.admin-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.admin-modal__header h3{margin:0;font-size:1.1rem}.admin-modal__close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1}.admin-modal__body{padding:1.5rem;overflow-y:auto;flex:1}.admin-modal__footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color)}.admin-checkbox-list{display:flex;flex-direction:column;gap:.25rem}.admin-checkbox-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:8px;cursor:pointer;font-size:.85rem;transition:background .1s ease}.admin-checkbox-item:hover{background:var(--hover-bg)}.admin-checkbox-item input[type=checkbox]{accent-color:var(--accent-blue)}.admin-text-secondary{color:var(--text-secondary)}.admin-text-truncate{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-text-nowrap{white-space:nowrap}.admin-loading{text-align:center;padding:3rem;color:var(--text-secondary);font-size:1rem}.admin-error{text-align:center;padding:3rem;color:#ef4444}.admin-empty{text-align:center;padding:3rem;color:var(--text-secondary)}.admin-form-label{display:block;font-size:.85rem;font-weight:600;color:var(--text-color);margin-bottom:.4rem}.admin-input{width:100%;padding:.55rem .75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-color);font-size:.85rem;outline:none;box-sizing:border-box;transition:border-color .15s ease}.admin-input:focus{border-color:var(--accent-blue)}.admin-input:disabled{opacity:.6;cursor:not-allowed}.admin-form-help{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:.35rem}.admin-alert{padding:.65rem .85rem;border-radius:8px;font-size:.85rem;margin-bottom:1rem}.admin-alert--error{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.25)}.admin-alert--success{background:#22c55e1f;color:#22c55e;border:1px solid rgba(34,197,94,.25)}@media (max-width: 900px){.admin-layout{flex-direction:column}.admin-sidebar{display:none}.admin-tabs-mobile{display:flex;overflow-x:auto;gap:0;background:var(--card-bg);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:10;-webkit-overflow-scrolling:touch}.admin-tabs-mobile__item{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.6rem .8rem;border:none;background:transparent;color:var(--text-secondary);font-size:.65rem;cursor:pointer;white-space:nowrap;min-width:0;flex-shrink:0;border-bottom:2px solid transparent;transition:all .15s ease}.admin-tabs-mobile__item--active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.admin-tabs-mobile__icon{font-size:1.1rem}.admin-content{padding:1rem}.admin-location-dropdown{min-width:0;max-width:100%;flex:1}.admin-page-header__controls{width:100%}.admin-metrics-grid{grid-template-columns:repeat(2,1fr)}.admin-charts-row{grid-template-columns:1fr}.admin-stats-row{gap:.75rem}.admin-stat{min-width:100px;padding:.75rem}.admin-page-title{font-size:1.25rem}}@media (max-width: 480px){.admin-metrics-grid{grid-template-columns:1fr 1fr;gap:.5rem}.admin-metrics-card{padding:.75rem}.admin-metrics-card__value{font-size:1.25rem}.admin-content{padding:.75rem}.admin-table{font-size:.75rem}.admin-table th,.admin-table td{padding:.4rem .5rem}.admin-table__col--hide-mobile{display:none}.admin-search-input{min-width:0;flex:1}.admin-text-truncate{max-width:140px}.admin-compare-search{font-size:.85rem}.admin-tabs-mobile__item{font-size:.7rem;padding:.5rem .6rem;min-height:44px}.admin-page-header{flex-direction:column;align-items:stretch;gap:.5rem}.admin-page-header__controls{flex-direction:column;width:100%}.admin-location-dropdown{min-width:0;max-width:100%;width:100%}.admin-location-dropdown__trigger{min-width:0;max-width:100%}.admin-stats-row .admin-stat{min-width:80px;padding:.5rem .75rem}.admin-filters-row{gap:.5rem}.admin-chart-card{padding:.75rem}.admin-opening-hours__time,.admin-opening-hours__day{font-size:.75rem}.admin-opening-hours__row{gap:.5rem}.admin-modal{max-width:100%;margin:.5rem;border-radius:12px}.admin-modal__header,.admin-modal__body{padding:1rem}.admin-modal__footer{padding:.75rem 1rem}.admin-charts-row{grid-template-columns:1fr;gap:.75rem}.admin-page-title{font-size:1.1rem;margin-bottom:1rem}.admin-time-range__btn{padding:.3rem .5rem;font-size:.75rem}}
