.home{min-height:100vh}.hero{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:var(--spacing-2xl) 0;text-align:center}.hero-content{max-width:900px;margin:0 auto}.hero-title{font-size:3.5rem;margin-bottom:var(--spacing-sm);color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.hero-subtitle{font-size:2rem;color:var(--secondary);margin-bottom:var(--spacing-lg);font-weight:400}.hero-description{font-size:1.25rem;line-height:1.8;margin-bottom:var(--spacing-2xl);opacity:.95}.hero-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-2xl)}.feature-item{background:#ffffff1a;padding:var(--spacing-lg);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-base)}.feature-item:hover{background:#ffffff26;transform:translateY(-5px)}.feature-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-sm)}.feature-item h3{color:#fff;font-size:1.25rem;margin-bottom:var(--spacing-xs)}.feature-item p{color:#ffffffe6;margin:0;font-size:.95rem}.how-it-works{padding:var(--spacing-2xl) 0;background:var(--bg-secondary)}.section-title{text-align:center;font-size:2.5rem;margin-bottom:var(--spacing-2xl);color:var(--primary-dark)}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-xl);max-width:1000px;margin:0 auto}.step{text-align:center;padding:var(--spacing-xl);background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:all var(--transition-base)}.step:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}.step-number{width:60px;height:60px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700;margin:0 auto var(--spacing-md);box-shadow:var(--shadow-md)}.step h3{font-size:1.5rem;margin-bottom:var(--spacing-sm)}.step p{color:var(--text-secondary);margin:0}.content-styles{padding:var(--spacing-2xl) 0;background:var(--bg-primary)}.styles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);max-width:1100px;margin:0 auto}.style-card{background:var(--bg-card);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border-left:4px solid var(--primary);transition:all var(--transition-base)}.style-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-left-width:6px}.style-card h3{font-size:1.5rem;margin-bottom:var(--spacing-md);color:var(--primary)}.style-card p{color:var(--text-secondary);margin-bottom:var(--spacing-md)}.reading-time{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);color:var(--text-muted);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500}.cta-section{padding:var(--spacing-2xl) 0;background:linear-gradient(135deg,var(--secondary-dark) 0%,var(--secondary) 100%);color:var(--text-primary)}.cta-section h2{font-size:2.5rem;color:var(--primary-dark);margin-bottom:var(--spacing-md)}.cta-section p{font-size:1.25rem;margin-bottom:var(--spacing-lg)}.cta-note{margin-top:var(--spacing-xl);padding:var(--spacing-lg);background:#ffffff80;border-radius:var(--radius-lg);max-width:600px;margin-left:auto;margin-right:auto}.footer{background:var(--primary-dark);color:#fff;padding:var(--spacing-xl) 0}.footer-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-lg)}.footer h4{color:var(--secondary);margin-bottom:var(--spacing-xs)}.footer .text-muted{color:#ffffffb3}.footer-link{color:var(--secondary);font-weight:500;transition:color var(--transition-fast)}.footer-link:hover{color:#fff}.footer-bottom{padding-top:var(--spacing-md);border-top:1px solid rgba(255,255,255,.2);text-align:center}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.5rem}.hero-description{font-size:1.1rem}.section-title{font-size:2rem}.footer-content{flex-direction:column;text-align:center}}.places-page{min-height:100vh;background:var(--bg-primary)}.places-header{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);color:#fff;padding:var(--spacing-xl) 0;box-shadow:var(--shadow-lg);margin-bottom:var(--spacing-2xl)}.places-header h1{color:#fff;font-size:2.5rem;margin-bottom:var(--spacing-sm)}.places-header p{color:#ffffffe6;font-size:1.125rem}.places-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.place-card{overflow:hidden;padding:0;transition:all var(--transition-base);cursor:pointer}.place-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}.place-card-image-wrapper{width:100%;height:250px;overflow:hidden;background:var(--bg-secondary)}.place-card-image{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.place-card:hover .place-card-image{transform:scale(1.1)}.place-card-content{padding:var(--spacing-xl)}.place-card-content h2{font-size:1.75rem;margin-bottom:var(--spacing-md);color:var(--primary-dark)}.place-card-description{color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-lg)}.place-card-footer{padding-top:var(--spacing-md);border-top:1px solid var(--border)}.explore-link{color:var(--primary);font-weight:600;font-size:1.125rem;transition:all var(--transition-fast);display:inline-block}.place-card:hover .explore-link{transform:translate(5px);color:var(--primary-dark)}@media (max-width: 768px){.places-grid{grid-template-columns:1fr}.places-header h1{font-size:2rem}}.content-selector{margin-bottom:var(--spacing-xl)}.selector-title{font-size:1.5rem;margin-bottom:var(--spacing-lg);color:var(--primary-dark);text-align:center}.selector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md)}.selector-btn{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-md);cursor:pointer;transition:all var(--transition-base);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.selector-btn:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow-md)}.selector-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-lg)}.selector-icon{font-size:2.5rem;display:block;margin-bottom:var(--spacing-xs)}.selector-info{width:100%}.selector-info h4{font-size:1.125rem;margin-bottom:var(--spacing-xs);color:inherit}.selector-btn.active .selector-info h4{color:#fff}.selector-desc{font-size:.875rem;color:var(--text-muted);margin-bottom:var(--spacing-xs)}.selector-btn.active .selector-desc{color:#ffffffe6}.selector-time{display:inline-block;font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-muted);font-weight:500}.selector-btn.active .selector-time{background:#fff3;color:#fff}@media (max-width: 480px){.selector-grid{grid-template-columns:repeat(2,1fr)}.selector-icon{font-size:2rem}}.indoor-map{margin-top:var(--spacing-xl)}.map-subtitle{color:var(--text-muted);font-size:.875rem;margin-top:calc(var(--spacing-sm) * -1);margin-bottom:var(--spacing-lg)}.map-container{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);overflow:hidden}.palace-svg{width:100%;height:auto;display:block}.nearby-marker{cursor:pointer;transition:all var(--transition-base)}.nearby-marker:hover{r:15;filter:drop-shadow(0 0 8px rgba(139,69,19,.5))}.place-label{font-family:var(--font-primary);font-weight:500}.current-location-marker{filter:drop-shadow(0 0 10px rgba(218,165,32,.6))}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.pulse{animation:pulse 2s ease-in-out infinite;transform-origin:center}.map-legend{display:flex;gap:var(--spacing-lg);justify-content:center;padding:var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;color:var(--text-secondary)}.legend-marker{display:inline-block;width:20px;height:20px;border-radius:50%;text-align:center;line-height:20px}.legend-marker.current{background:var(--secondary);font-size:14px}.legend-marker.nearby{background:var(--accent);border:2px solid var(--primary)}.nearby-list{padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.nearby-list h4{font-size:1rem;margin-bottom:var(--spacing-md);color:var(--primary-dark)}.nearby-list ul{list-style:none;padding:0;margin:0}.nearby-list li{padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border)}.nearby-list li:last-child{border-bottom:none}.nearby-link{color:var(--primary);font-weight:500;text-decoration:none;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--spacing-sm)}.nearby-link:before{content:"→";transition:transform var(--transition-fast)}.nearby-link:hover{color:var(--primary-dark);padding-left:var(--spacing-sm)}.nearby-link:hover:before{transform:translate(5px)}@media (max-width: 768px){.map-legend{flex-direction:column;align-items:flex-start}}.crowd-insights{margin-top:var(--spacing-xl)}.crowd-level-section{text-align:center;padding:var(--spacing-lg);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.crowd-level-label{font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-sm);font-weight:600}.crowd-level-badge{display:inline-block;padding:var(--spacing-sm) var(--spacing-xl);font-size:1.5rem;font-weight:700;border-radius:var(--radius-lg);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:1px;box-shadow:var(--shadow-md)}.crowd-level-badge.crowd-low{background:var(--crowd-low);color:#fff}.crowd-level-badge.crowd-medium{background:var(--crowd-medium);color:#fff}.crowd-level-badge.crowd-high{background:var(--crowd-high);color:#fff}.crowd-detail{font-size:.875rem;color:var(--text-secondary);margin-top:var(--spacing-sm)}.peak-hours-section{padding:var(--spacing-lg);background:var(--bg-primary);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.peak-hours-section h4{font-size:1.125rem;margin-bottom:var(--spacing-md);color:var(--primary-dark)}.peak-hours-info{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#fff;border-radius:var(--radius-md);border-left:4px solid var(--secondary);margin-bottom:var(--spacing-sm)}.peak-icon{font-size:1.5rem}.peak-hours-text{font-size:1rem;font-weight:500;color:var(--text-primary);flex:1}.peak-note{font-size:.875rem;color:var(--text-muted);font-style:italic;margin:0;margin-top:var(--spacing-sm)}.crowd-tips{padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.crowd-tips h4{font-size:1rem;margin-bottom:var(--spacing-sm);color:var(--primary)}.crowd-tips ul{list-style:none;padding:0;margin:0}.crowd-tips li{padding:var(--spacing-xs) 0;color:var(--text-secondary);font-size:.875rem;position:relative;padding-left:var(--spacing-lg)}.crowd-tips li:before{content:"✓";position:absolute;left:0;color:var(--success);font-weight:700}.place-detail{min-height:100vh;display:flex;flex-direction:column}.place-header{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);color:#fff;padding:var(--spacing-xl) 0;box-shadow:var(--shadow-lg)}.back-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--secondary);font-weight:500;margin-bottom:var(--spacing-md);transition:all var(--transition-fast)}.back-link:hover{color:#fff;transform:translate(-5px)}.place-title{font-size:3rem;margin-bottom:var(--spacing-md);color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.place-description{font-size:1.25rem;color:#fffffff2;max-width:800px;line-height:1.6}.place-content-grid{display:grid;grid-template-columns:1fr 400px;gap:var(--spacing-xl);padding:var(--spacing-xl) 0;flex:1}.content-column{min-width:0}.sidebar-column{position:sticky;top:var(--spacing-lg);align-self:start}.place-image-container{margin-bottom:var(--spacing-xl);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.place-image{width:100%;height:auto;display:block;transition:transform var(--transition-slow)}.place-image-container:hover .place-image{transform:scale(1.05)}.content-display{animation:fadeIn var(--transition-base) ease-out}.content-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border)}.content-header h2{margin:0;color:var(--primary-dark);flex:1}.content-body{margin-bottom:var(--spacing-lg)}.content-text{font-size:1.125rem;line-height:1.8;color:var(--text-primary);white-space:pre-line}.content-footer{padding-top:var(--spacing-md);border-top:1px solid var(--border)}.reading-time{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--text-muted);font-size:.875rem}.place-footer{margin-top:auto;padding:var(--spacing-lg) 0;background:var(--bg-secondary);border-top:1px solid var(--border)}.error-container{padding:var(--spacing-2xl) 0;text-align:center}.error-container h2{margin-bottom:var(--spacing-md)}@media (max-width: 1024px){.place-content-grid{grid-template-columns:1fr}.sidebar-column{position:static}}@media (max-width: 768px){.place-title{font-size:2rem}.place-description{font-size:1.1rem}.content-text{font-size:1rem}.content-header{flex-direction:column;align-items:flex-start}}@media (max-width: 480px){.place-header{padding:var(--spacing-lg) 0}.place-title{font-size:1.75rem}}.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 50%,var(--secondary) 100%);padding:var(--spacing-lg)}.login-container{width:100%;max-width:450px}.login-card{padding:var(--spacing-2xl);box-shadow:var(--shadow-xl)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-header h1{font-size:2rem;color:var(--primary-dark);margin-bottom:var(--spacing-sm)}.login-form{margin-bottom:var(--spacing-lg)}.login-form .btn{width:100%;margin-top:var(--spacing-md)}.login-footer{text-align:center;padding-top:var(--spacing-lg);border-top:1px solid var(--border)}.back-home-link{color:var(--primary);font-weight:500;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:var(--spacing-xs)}.back-home-link:hover{color:var(--primary-dark);transform:translate(-5px)}.demo-credentials{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);text-align:center;border-left:4px solid var(--secondary)}.demo-credentials p{margin:0;line-height:1.6}@media (max-width: 480px){.login-card{padding:var(--spacing-xl)}.login-header h1{font-size:1.75rem}}.admin-dashboard{min-height:100vh;background:var(--bg-primary)}.admin-header{background:var(--primary-dark);color:#fff;padding:var(--spacing-lg) 0;box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl)}.header-content{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);flex-wrap:wrap}.admin-header h1{color:#fff;margin-bottom:var(--spacing-xs);font-size:2rem}.admin-header .text-muted{color:#fffc}.header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.user-info{color:var(--secondary);font-weight:500}.dashboard-content{padding:var(--spacing-xl) var(--spacing-lg)}.welcome-section{text-align:center;margin-bottom:var(--spacing-2xl)}.welcome-section h2{font-size:2rem;margin-bottom:var(--spacing-sm)}.welcome-section p{font-size:1.125rem;color:var(--text-secondary)}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.action-card{text-align:center;padding:var(--spacing-xl);text-decoration:none;color:var(--text-primary);transition:all var(--transition-base);border:2px solid transparent}.action-card:hover{border-color:var(--primary);transform:translateY(-5px);box-shadow:var(--shadow-xl)}.action-icon{font-size:4rem;margin-bottom:var(--spacing-md)}.action-card h3{font-size:1.5rem;margin-bottom:var(--spacing-sm);color:var(--primary-dark)}.action-card p{color:var(--text-secondary);margin-bottom:var(--spacing-md)}.action-link{display:inline-block;color:var(--primary);font-weight:600;transition:all var(--transition-fast)}.action-card:hover .action-link{transform:translate(5px)}.info-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg)}.info-card h3{font-size:1.25rem;margin-bottom:var(--spacing-md);color:var(--primary-dark)}.info-card ul{list-style:none;padding:0;margin:0}.info-card li{padding:var(--spacing-sm) 0;color:var(--text-secondary);position:relative;padding-left:var(--spacing-lg)}.info-card li:before{content:"•";position:absolute;left:0;color:var(--primary);font-weight:700;font-size:1.5rem;line-height:1}.status-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border)}.status-item:last-child{border-bottom:none}.status-label{font-weight:500;color:var(--text-primary)}@media (max-width: 768px){.header-content{flex-direction:column;align-items:flex-start}.header-actions{width:100%;justify-content:space-between}.quick-actions-grid{grid-template-columns:1fr}}.places-management{min-height:100vh;background:var(--bg-primary)}.places-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg)}.place-card{overflow:hidden;transition:all .3s ease}.place-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.place-card-image{width:100%;height:200px;object-fit:cover}.place-card-content{padding:var(--spacing-md)}.place-card-content h3{margin:0 0 var(--spacing-sm) 0;font-size:1.25rem}.place-card-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin:var(--spacing-md) 0}.place-card-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-md)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.modal-large{max-width:900px}.photo-upload-form{padding:var(--spacing-lg);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.photo-upload-form h3{margin-top:0;margin-bottom:var(--spacing-md)}.photo-gallery{margin-top:var(--spacing-xl)}.photo-gallery h3{margin-bottom:var(--spacing-md)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-md)}.photo-item{background:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden;transition:all .3s ease}.photo-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.photo-thumbnail{width:100%;height:200px;object-fit:cover}.photo-info{padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-input-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.875rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md)}@media (max-width: 768px){.places-grid,.form-row,.photo-grid{grid-template-columns:1fr}.place-card-actions{flex-direction:column}.place-card-actions .btn{width:100%}}.content-management{min-height:100vh;background:var(--bg-primary)}.content-item{padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);transition:all .3s ease}.content-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.content-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.btn-danger{background:var(--error);color:#fff;border:none}.btn-danger:hover{background:#c0392b}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:var(--bg-primary);border-radius:var(--radius-lg);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.5rem}.modal-close{background:none;border:none;font-size:2rem;cursor:pointer;color:var(--text-secondary);line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--border-color)}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--text-primary)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:all .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3498db1a}.form-textarea{resize:vertical;font-family:inherit}.form-input:disabled,.form-select:disabled{opacity:.6;cursor:not-allowed}.alert-error{background:#e74c3c1a;color:var(--error);border:1px solid var(--error)}.alert-success{background:#2ecc711a;color:#27ae60;border:1px solid #27ae60}@media (max-width: 768px){.modal-content{max-height:95vh}.grid-2{grid-template-columns:1fr!important}}.analytics-page{min-height:100vh;background:var(--bg-primary)}.live-indicator{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);font-size:.875rem}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.live{background:#27ae60;animation:pulse 2s infinite}.status-dot.paused{background:#95a5a6}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.status-text{font-weight:600;color:var(--text-primary)}.last-update{color:var(--text-secondary);font-size:.8rem;margin-left:var(--spacing-xs);padding-left:var(--spacing-xs);border-left:1px solid var(--border-color)}.update-times{display:flex;flex-direction:column;gap:2px;margin-left:var(--spacing-xs);padding-left:var(--spacing-xs);border-left:1px solid var(--border-color)}.update-label{color:var(--text-secondary);font-size:.75rem}.update-badge{display:inline-block;padding:2px 8px;background:#3498db1a;color:var(--primary);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;margin-bottom:var(--spacing-xs)}.chart-badge{background:#8e44ad1a;color:#8e44ad}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.stat-card{transition:all .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.stat-number{font-size:2.5rem;color:var(--primary);margin:0;font-weight:700;transition:all .5s ease}.stat-number.stat-secondary{color:var(--secondary)}.stat-number.stat-accent{color:var(--accent)}.chart-card{transition:all .3s ease}.chart-card:hover{box-shadow:0 4px 16px #0000001a}.table-row{transition:background-color .2s ease}.table-row:hover{background-color:var(--bg-secondary)}.card{animation:fadeIn .3s ease}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--spacing-md)}.spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.live-indicator{flex-direction:column;align-items:flex-start;gap:var(--spacing-xxs)}.last-update{border-left:none;padding-left:0;margin-left:0}.stat-number{font-size:2rem}}.qr-generator{min-height:100vh;background:var(--bg-primary)}.qr-header{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);color:#fff;padding:var(--spacing-xl) 0;box-shadow:var(--shadow-lg);margin-bottom:var(--spacing-2xl)}.qr-header h1{color:#fff;font-size:2.5rem;margin-bottom:var(--spacing-sm)}.qr-header p{color:#ffffffe6;font-size:1.125rem}.url-config{margin-bottom:var(--spacing-2xl)}.url-config h3{margin-bottom:var(--spacing-md)}.url-config input{margin-top:var(--spacing-md)}.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.qr-card{text-align:center}.qr-card h3{margin-bottom:var(--spacing-lg);color:var(--primary-dark)}.qr-image-container{background:#fff;padding:var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);border:2px solid var(--border)}.qr-image{width:100%;max-width:300px;height:auto;display:block;margin:0 auto}.qr-url{background:var(--bg-secondary);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);word-break:break-all}.qr-url code{display:block;margin-top:var(--spacing-xs);font-size:.875rem;color:var(--text-secondary);background:#fff;padding:var(--spacing-sm);border-radius:var(--radius-sm)}.qr-actions{display:flex;gap:var(--spacing-sm);justify-content:center;flex-wrap:wrap}.instructions ol{padding-left:var(--spacing-xl);line-height:1.8}.instructions li{margin-bottom:var(--spacing-md);color:var(--text-secondary)}.instructions strong{color:var(--text-primary)}@media (max-width: 768px){.qr-grid{grid-template-columns:1fr}.qr-actions{flex-direction:column}.qr-actions .btn{width:100%}}.crowd-control{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.crowd-header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 20px #0000001a;padding:2rem 0;margin-bottom:2rem}.crowd-header .header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;flex-wrap:wrap}.crowd-header h1{font-size:2rem;color:#2d3748;margin:.5rem 0 .25rem}.crowd-header .text-muted{color:#718096;font-size:.95rem}.btn-back{background:none;border:none;color:#667eea;font-size:.95rem;cursor:pointer;padding:.5rem 0;margin-bottom:.5rem;transition:color .3s}.btn-back:hover{color:#764ba2}.header-status{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem;transition:all .3s}.status-badge.live{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 15px #10b9814d}.status-badge.offline{background:#e2e8f0;color:#64748b}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.status-badge.live .status-dot{animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.last-update{font-size:.85rem;color:#64748b}.crowd-content{padding:0 1rem 3rem}.loading-state,.error-state,.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a}.spinner{width:50px;height:50px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.error-message{color:#dc2626;font-size:1.1rem;margin-bottom:1rem}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{color:#2d3748;margin-bottom:.5rem}.empty-state p{color:#64748b;margin-bottom:2rem}.info-box{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;padding:1.5rem;text-align:left;max-width:600px;margin:0 auto}.info-box h4{color:#2d3748;margin-bottom:1rem}.info-box ol{margin-left:1.5rem;color:#4a5568}.info-box code{background:#edf2f7;padding:.25rem .5rem;border-radius:4px;font-size:.9rem;color:#667eea;display:inline-block;margin:.25rem 0}.crowd-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.crowd-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 20px #0000001a;transition:all .3s;border-left:4px solid;animation:fadeIn .5s}.crowd-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #00000026}.crowd-card.low{border-left-color:#10b981}.crowd-card.medium{border-left-color:#f59e0b}.crowd-card.high{border-left-color:#ef4444}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.card-header h3{color:#2d3748;font-size:1.25rem;margin:0;flex:1}.crowd-badge{padding:.35rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;white-space:nowrap}.crowd-badge.low{background:#d1fae5;color:#065f46}.crowd-badge.medium{background:#fed7aa;color:#92400e}.crowd-badge.high{background:#fee2e2;color:#991b1b}.crowd-metrics{margin-bottom:1.5rem}.metric-large{text-align:center;padding:1.5rem;background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:8px;margin-bottom:1rem}.metric-large .metric-value{font-size:3rem;font-weight:700;color:#2d3748;line-height:1}.metric-large .metric-label{color:#64748b;font-size:.9rem;margin-top:.5rem;text-transform:uppercase;letter-spacing:.5px}.metrics-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.metric{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f7fafc;border-radius:8px}.metric-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff}.metric-icon.entry{background:linear-gradient(135deg,#10b981,#059669)}.metric-icon.exit{background:linear-gradient(135deg,#3b82f6,#2563eb)}.metric-value-sm{font-size:1.5rem;font-weight:700;color:#2d3748;line-height:1}.metric-label-sm{color:#64748b;font-size:.8rem;margin-top:.25rem}.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid #e2e8f0;font-size:.85rem;color:#64748b}.location-id{font-family:monospace;background:#f7fafc;padding:.25rem .5rem;border-radius:4px}@media (max-width: 768px){.crowd-header .header-content{flex-direction:column;align-items:flex-start}.header-status{align-items:flex-start}.crowd-grid{grid-template-columns:1fr}.crowd-header h1{font-size:1.5rem}.metric-large .metric-value{font-size:2.5rem}}.btn{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s;border:none;font-size:1rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.container{max-width:1400px;margin:0 auto;padding:0 1rem}:root{--primary: #8B4513;--primary-dark: #654321;--primary-light: #A0522D;--secondary: #DAA520;--secondary-dark: #B8860B;--accent: #CD853F;--bg-primary: #FFFAF0;--bg-secondary: #FFF8DC;--bg-card: #FFFFFF;--text-primary: #2C1810;--text-secondary: #5C4033;--text-muted: #8B7355;--border: #D4C4B0;--shadow: rgba(139, 69, 19, .1);--success: #2E7D32;--warning: #F57C00;--error: #C62828;--info: #0277BD;--crowd-low: #4CAF50;--crowd-medium: #FF9800;--crowd-high: #F44336;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--font-primary: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;--font-heading: "Georgia", serif;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 2px 4px var(--shadow);--shadow-md: 0 4px 8px var(--shadow);--shadow-lg: 0 8px 16px var(--shadow);--shadow-xl: 0 12px 24px var(--shadow);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-primary);color:var(--text-primary);background:var(--bg-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.3;color:var(--primary-dark);margin-bottom:var(--spacing-md)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-bottom:var(--spacing-md)}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-dark)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:1rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-decoration:none;font-family:var(--font-primary)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--secondary);color:var(--text-primary)}.btn-secondary:hover{background:var(--secondary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:.875rem}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:1.125rem}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border)}.card-title{font-size:1.5rem;margin-bottom:var(--spacing-sm)}.card-body{margin-bottom:var(--spacing-md)}.card-footer{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-primary)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:1rem;font-family:var(--font-primary);color:var(--text-primary);background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #8b45131a}.form-textarea{resize:vertical;min-height:100px}.form-error{color:var(--error);font-size:.875rem;margin-top:var(--spacing-xs)}.badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;font-weight:600;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px}.badge-low{background:var(--crowd-low);color:#fff}.badge-medium{background:var(--crowd-medium);color:#fff}.badge-high{background:var(--crowd-high);color:#fff}.badge-primary{background:var(--primary);color:#fff}.badge-secondary{background:var(--secondary);color:var(--text-primary)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.container-sm{max-width:800px}.container-lg{max-width:1400px}.grid{display:grid;gap:var(--spacing-lg)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.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-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-primary{color:var(--primary)}.text-secondary{color:var(--text-secondary)}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.font-bold{font-weight:600}.font-normal{font-weight:400}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;justify-content:center;align-items:center;min-height:200px}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.alert-success{background:#e8f5e9;color:var(--success);border-left:4px solid var(--success)}.alert-error{background:#ffebee;color:var(--error);border-left:4px solid var(--error)}.alert-warning{background:#fff3e0;color:var(--warning);border-left:4px solid var(--warning)}.alert-info{background:#e3f2fd;color:var(--info);border-left:4px solid var(--info)}@media (max-width: 768px){html{font-size:14px}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.container{padding:0 var(--spacing-md)}}@media (max-width: 480px){html{font-size:13px}.btn{width:100%}.card{padding:var(--spacing-md)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-base) ease-out}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}*:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
