@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Playfair+Display:wght@400;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Inter:wght@300;400;500;600;700&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}button{cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}input,select,textarea{font-family:inherit}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}:focus{outline:2px solid #667eea;outline-offset:2px}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #667eea}@media print{*{background:#fff!important;box-shadow:none!important;color:#000!important;text-shadow:none!important}}:root{--primary-gradient:linear-gradient(135deg,#667eea,#764ba2);--secondary-gradient:linear-gradient(135deg,#f093fb,#f5576c);--accent-gradient:linear-gradient(135deg,#4facfe,#00f2fe);--gold-gradient:linear-gradient(135deg,#f7971e,#ffd200);--success-gradient:linear-gradient(135deg,#11998e,#38ef7d);--text-primary:#2d3748;--text-secondary:#718096;--text-light:#a0aec0;--bg-white:#fff;--bg-light:#f7fafc;--bg-overlay:#fffffff2;--shadow-light:0 4px 6px #0000000d;--shadow-medium:0 10px 25px #0000001a;--shadow-heavy:0 20px 40px #00000026;--shadow-brutal:0 25px 50px #00000040;--border-radius:12px;--border-radius-lg:20px;--transition:all 0.3s cubic-bezier(0.4,0,0.2,1);--transition-bounce:all 0.4s cubic-bezier(0.68,-0.55,0.265,1.55)}.login-page{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh;overflow:hidden;position:relative}.background-elements{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}.floating-circle{animation:float 6s ease-in-out infinite;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:50%;position:absolute}.circle-1{animation-delay:0s;height:100px;left:10%;top:10%;width:100px}.circle-2{animation-delay:2s;height:150px;right:15%;top:20%;width:150px}.circle-3{animation-delay:4s;bottom:30%;height:80px;left:20%;width:80px}.circle-4{animation-delay:1s;bottom:10%;height:120px;right:10%;width:120px}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(180deg)}}.login-layout{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;display:grid;grid-template-columns:1fr 500px;min-height:100vh;position:relative;z-index:2}.login-visual{align-items:center;display:flex;justify-content:center;overflow:hidden;position:relative}.hero-image{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.background-image{filter:brightness(.7) contrast(1.1) saturate(1.2);height:100%;object-fit:cover;width:100%}.visual-overlay{align-items:center;background:linear-gradient(135deg,#0003,#0000001a 50%,#0003);display:flex;height:100%;justify-content:center;padding:4rem;position:relative;width:100%;z-index:2}.brand-section{animation:slideInLeft 1s ease-out;color:#fff;text-align:center}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}.brand-logo{margin-bottom:4rem}.logo-icon{animation:bounce 2s ease-in-out infinite;filter:drop-shadow(0 10px 20px rgba(0,0,0,.3));font-size:5rem;margin-bottom:1rem}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-15px)}60%{transform:translateY(-8px)}}.brand-logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#fff,#f0f8ff,#e6f3ff);-webkit-background-clip:text;background-clip:text;font-family:Playfair Display,serif;font-size:4rem;font-weight:700;letter-spacing:3px;margin-bottom:1rem;text-shadow:0 4px 8px #0000004d}.brand-tagline{display:flex;flex-direction:column;font-size:1.3rem;font-weight:300;gap:.5rem;letter-spacing:1px;opacity:.9}.feature-highlights{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.feature-item{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;border-radius:var(--border-radius);display:flex;gap:1rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.feature-item:hover{background:#ffffff26;transform:translateY(-5px)}.feature-item h3{font-size:1rem;font-weight:600;margin-bottom:.25rem}.feature-item p{font-size:.85rem;opacity:.8}.feature-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));font-size:2rem}.login-form-section{animation:slideInRight 1s ease-out;background:#fff;background:var(--bg-white);display:flex;flex-direction:column;position:relative}@keyframes slideInRight{0%{opacity:0;transform:translateX(50px)}to{opacity:1;transform:translateX(0)}}.form-container{display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:4rem 3rem}.form-header{margin-bottom:3rem;text-align:center}.form-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text;color:#2d3748;color:var(--text-primary);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.form-header p{color:#718096;color:var(--text-secondary);font-size:1.1rem;font-weight:400}.error-message{align-items:center;animation:shake .5s ease-in-out;background:linear-gradient(135deg,#f093fb,#f5576c);background:var(--secondary-gradient);border-radius:12px;border-radius:var(--border-radius);box-shadow:0 10px 25px #0000001a;box-shadow:var(--shadow-medium);color:#fff;display:flex;font-weight:500;gap:.75rem;margin-bottom:2rem;padding:1rem 1.5rem}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.error-icon{font-size:1.2rem}.login-form{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#2d3748;color:var(--text-primary);display:block;font-size:.95rem;margin-bottom:.75rem}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#718096;color:var(--text-secondary);font-size:1.1rem;left:1.25rem;position:absolute;z-index:1}.input-wrapper input{background:#f7fafc;background:var(--bg-light);border:2px solid #e2e8f0;border-radius:12px;border-radius:var(--border-radius);font-size:1rem;font-weight:500;padding:1.25rem 1.25rem 1.25rem 3.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:100%}.input-wrapper input:focus{background:#fff;background:var(--bg-white);border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none;transform:translateY(-1px)}.input-wrapper input:disabled{cursor:not-allowed;opacity:.7}.password-toggle{background:none;border:none;border-radius:6px;cursor:pointer;font-size:1.1rem;padding:.5rem;position:absolute;right:1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.password-toggle:hover{background:#667eea1a}.login-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);border:none;border-radius:12px;border-radius:var(--border-radius);box-shadow:0 10px 25px #0000001a;box-shadow:var(--shadow-medium);color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:.75rem;justify-content:center;margin-bottom:2rem;overflow:hidden;padding:1.25rem 2rem;position:relative;transition:all .4s cubic-bezier(.68,-.55,.265,1.55);transition:var(--transition-bounce);width:100%}.login-button:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.login-button:hover:before{left:100%}.login-button:hover:not(:disabled){box-shadow:0 20px 40px #00000026;box-shadow:var(--shadow-heavy);transform:translateY(-3px)}.login-button:active{transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.8;transform:none}.loading-spinner{border:2px solid #ffffff4d;border-top-color:#fff;height:20px;width:20px}.divider{margin:2rem 0;position:relative;text-align:center}.divider:before{background:linear-gradient(90deg,#0000,#e2e8f0,#0000);content:"";height:1px;left:0;position:absolute;right:0;top:50%}.divider span{background:#fff;background:var(--bg-white);color:#718096;color:var(--text-secondary);font-size:.9rem;font-weight:500;padding:0 1.5rem}.demo-buttons{display:flex;gap:1rem;margin-bottom:2rem}.demo-button{align-items:center;background:#fff;background:var(--bg-white);border:2px solid #e2e8f0;border-radius:12px;border-radius:var(--border-radius);cursor:pointer;display:flex;flex:1 1;gap:1rem;padding:1.5rem;text-align:left;transition:all .4s cubic-bezier(.68,-.55,.265,1.55);transition:var(--transition-bounce)}.demo-button:hover:not(:disabled){box-shadow:0 10px 25px #0000001a;box-shadow:var(--shadow-medium);transform:translateY(-3px)}.demo-button.super-admin:hover{background:linear-gradient(135deg,#fff8e1,#fff);border-color:#f7971e}.demo-button.admin:hover{background:linear-gradient(135deg,#f0f4ff,#fff);border-color:#667eea}.demo-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:2rem}.demo-content strong{color:#2d3748;color:var(--text-primary);display:block;font-weight:600;margin-bottom:.25rem}.demo-content small{color:#718096;color:var(--text-secondary);font-size:.85rem}.seed-section{background:#f7fafc;background:var(--bg-light);border:1px solid #e2e8f0;border-radius:12px;border-radius:var(--border-radius);padding:1.5rem;text-align:center}.seed-section p{color:#718096;color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.seed-button{align-items:center;background:linear-gradient(135deg,#11998e,#38ef7d);background:var(--success-gradient);border:none;border-radius:12px;border-radius:var(--border-radius);box-shadow:0 4px 6px #0000000d;box-shadow:var(--shadow-light);color:#fff;cursor:pointer;display:inline-flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.seed-button:hover{box-shadow:0 10px 25px #0000001a;box-shadow:var(--shadow-medium);transform:translateY(-2px)}.login-footer{background:#f7fafc;background:var(--bg-light);border-top:1px solid #e2e8f0;padding:2rem 3rem;text-align:center}.security-badge{align-items:center;background:#667eea1a;border-radius:20px;color:#667eea;display:inline-flex;font-size:.85rem;font-weight:500;gap:.5rem;margin-bottom:1rem;padding:.5rem 1rem}.security-icon{font-size:1rem}.login-footer p{color:#a0aec0;color:var(--text-light);font-size:.85rem;margin:0}@media (max-width:1024px){.login-layout{grid-template-columns:1fr}.login-visual{display:none}}@media (max-width:768px){.form-container{padding:3rem 2rem}.form-header h2{font-size:2rem}.demo-buttons{flex-direction:column}.feature-highlights{gap:1rem;grid-template-columns:1fr}}@media (max-width:480px){.form-container{padding:2rem 1.5rem}.form-header h2{font-size:1.75rem}.login-footer{padding:1.5rem}}@media (prefers-color-scheme:dark){:root{--text-primary:#f7fafc;--text-secondary:#a0aec0;--bg-white:#1a202c;--bg-light:#2d3748}}:root{--primary-color:#2c3e50;--secondary-color:#34495e;--accent-color:#3498db;--success-color:#27ae60;--warning-color:#f39c12;--error-color:#e74c3c;--text-primary:#2c3e50;--text-secondary:#7f8c8d;--background-primary:#fff;--background-secondary:#f8f9fa;--border-color:#e9ecef;--shadow-light:0 2px 4px #0000001a;--shadow-medium:0 4px 12px #00000026;--shadow-heavy:0 8px 25px #0003;--border-radius:8px;--transition:all 0.3s ease}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f8f9fa;background-color:var(--background-secondary);color:#2c3e50;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}.App{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#2c3e50,#34495e);background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);box-shadow:0 4px 12px #00000026;box-shadow:var(--shadow-medium);color:#fff;padding:1rem 0;position:sticky;top:0;z-index:100}.header-content{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 2rem}.app-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#fff,#ecf0f1);-webkit-background-clip:text;background-clip:text;font-family:Playfair Display,serif;font-size:2rem;font-weight:600}.main-nav{flex-wrap:wrap;gap:.5rem}.main-nav,.nav-btn{align-items:center;display:flex}.nav-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;border-radius:var(--border-radius);color:#fff;cursor:pointer;flex-direction:column;font-size:.85rem;gap:.25rem;min-width:80px;padding:.75rem 1rem;text-decoration:none;transition:all .3s ease;transition:var(--transition)}.nav-btn:hover{background:#fff3;box-shadow:0 4px 15px #0003;transform:translateY(-2px)}.nav-btn.active{background:#ffffff40;border-color:#fff6;transform:translateY(-1px)}.nav-icon{font-size:1.2rem;line-height:1}.nav-label{font-size:.75rem;font-weight:500;line-height:1.2;text-align:center}.app-main{flex:1 1;padding:2rem 0}.content-container{margin:0 auto;max-width:1400px;padding:0 2rem}.page{background:#fff;background:var(--background-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);margin-bottom:2rem;padding:2rem}.page h2{border-bottom:3px solid #3498db;border-bottom:3px solid var(--accent-color);color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:2rem;margin-bottom:1.5rem;padding-bottom:.5rem}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e9ecef;border-top:4px solid #3498db;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-color);height:48px;margin-bottom:1rem;width:48px}.error-container{background:#fff;border:1px solid #e74c3c;border:1px solid var(--error-color);border-radius:8px;border-radius:var(--border-radius);margin:2rem 0;padding:2rem;text-align:center}.error-container h3{color:#e74c3c;color:var(--error-color);margin-bottom:1rem}.error-container button{background:#e74c3c;background:var(--error-color);border:none;border-radius:8px;border-radius:var(--border-radius);color:#fff;cursor:pointer;margin-top:1rem;padding:.75rem 1.5rem;transition:all .3s ease;transition:var(--transition)}.error-container button:hover{opacity:.9;transform:translateY(-1px)}.connection-status{background:#fff;background:var(--background-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);font-weight:500;margin-bottom:2rem;padding:1rem 1.5rem;text-align:center}.connection-status.connected{border-left:4px solid #27ae60;border-left:4px solid var(--success-color);color:#27ae60;color:var(--success-color)}.connection-status.disconnected{border-left:4px solid #f39c12;border-left:4px solid var(--warning-color);color:#f39c12;color:var(--warning-color)}.dashboard{background:#fff;background:var(--background-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);padding:2rem}.dashboard h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2c3e50,#3498db);background:linear-gradient(135deg,var(--primary-color),var(--accent-color));-webkit-background-clip:text;background-clip:text;color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:2.2rem;margin-bottom:2rem;text-align:center}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:3rem}.stat-card{background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);overflow:hidden;position:relative;text-align:center;transition:var(--transition)}.stat-card:before{background:linear-gradient(90deg,#3498db,#27ae60);background:linear-gradient(90deg,var(--accent-color),var(--success-color));content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:hover{box-shadow:0 4px 12px #00000026;box-shadow:var(--shadow-medium)}.stat-card h3{color:#7f8c8d;color:var(--text-secondary);font-size:.9rem;font-weight:600;letter-spacing:1px;margin-bottom:1rem;text-transform:uppercase}.stat-value{color:#2c3e50;color:var(--primary-color);font-family:Inter,sans-serif;font-size:2.5rem;font-weight:700;line-height:1}.dashboard-sections{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(500px,1fr))}.section{background:#fff;background:var(--background-primary);border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);padding:1.5rem}.section h3{border-bottom:2px solid #3498db;border-bottom:2px solid var(--accent-color);color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:1.3rem;margin-bottom:1.5rem;padding-bottom:.5rem}.recent-bookings{display:flex;flex-direction:column;gap:1rem}.booking-item{align-items:center;background:#f8f9fa;background:var(--background-secondary);border-left:3px solid #3498db;border-left:3px solid var(--accent-color);border-radius:8px;border-radius:var(--border-radius);display:flex;justify-content:space-between;padding:1rem;transition:all .3s ease;transition:var(--transition)}.booking-item:hover{box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);transform:translateX(4px)}.booking-info{display:flex;flex-direction:column;gap:.25rem}.booking-info strong{color:#2c3e50;color:var(--primary-color);font-weight:600}.booking-info span{color:#7f8c8d;color:var(--text-secondary);font-size:.85rem}.booking-amount{color:#27ae60;color:var(--success-color);font-size:1.1rem;font-weight:700}.hall-performance{display:flex;flex-direction:column;gap:1rem}.hall-item{align-items:center;background:#f8f9fa;background:var(--background-secondary);border-left:3px solid #27ae60;border-left:3px solid var(--success-color);border-radius:8px;border-radius:var(--border-radius);display:flex;justify-content:space-between;padding:1rem;transition:all .3s ease;transition:var(--transition)}.hall-item:hover{box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);transform:translateX(4px)}.hall-info{display:flex;flex-direction:column;gap:.25rem}.hall-info strong{color:#2c3e50;color:var(--primary-color);font-weight:600}.hall-info span{color:#7f8c8d;color:var(--text-secondary);font-size:.85rem}.hall-revenue{color:#3498db;color:var(--accent-color);font-size:1.1rem;font-weight:700}.hall-booking-calendar{background:#fff;background:var(--background-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);padding:2rem}.hall-booking-calendar h2{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:2.2rem;margin-bottom:2rem;text-align:center}.hall-selection{margin-bottom:3rem}.hall-selection h3{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.halls-grid{grid-gap:1.5rem;gap:1.5rem}.hall-card{background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e9ecef;border:2px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);cursor:pointer;padding:1.5rem;position:relative;text-align:center;transition:var(--transition)}.hall-card:before{background:linear-gradient(90deg,#3498db,#27ae60);background:linear-gradient(90deg,var(--accent-color),var(--success-color));content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.hall-card:hover:before{transform:scaleX(1)}.hall-card:hover{transform:translateY(-4px)}.hall-card.selected,.hall-card:hover{border-color:#3498db;border-color:var(--accent-color);box-shadow:0 4px 12px #00000026;box-shadow:var(--shadow-medium)}.hall-card.selected{background:linear-gradient(135deg,#e3f2fd,#fff);transform:translateY(-2px)}.hall-card.selected:before{transform:scaleX(1)}.hall-card h4{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:1.3rem}.pricing{display:flex;gap:1rem;justify-content:space-between}.pricing span{background:#f8f9fa;background:var(--background-secondary);border-radius:20px;color:#2c3e50;color:var(--primary-color);flex:1 1;font-size:.85rem;font-weight:600;padding:.5rem 1rem;text-align:center}.calendar-section{margin-top:3rem}.calendar-section h3{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:1.5rem;margin-bottom:2rem;text-align:center}.calendar-grid{grid-gap:1rem;background:#f8f9fa;background:var(--background-secondary);border-radius:8px;border-radius:var(--border-radius);gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));max-height:600px;overflow-y:auto;padding:1rem}.calendar-date{background:var(--background-primary);border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);padding:1rem;transition:all .3s ease;transition:var(--transition)}.calendar-date.past{opacity:.5}.calendar-date:not(.past):hover{box-shadow:0 4px 12px #00000026;box-shadow:var(--shadow-medium);transform:translateY(-2px)}.date-header{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);color:#2c3e50;color:var(--primary-color);margin-bottom:1rem;padding-bottom:.5rem;text-align:center}.slots{gap:.5rem}.slot{border-radius:8px;border-radius:var(--border-radius);font-size:.85rem;font-weight:500;padding:.75rem;position:relative}.slot.available{background:linear-gradient(135deg,#e8f5e8,#fff);border:1px solid #27ae60;border:1px solid var(--success-color);color:#27ae60;color:var(--success-color)}.slot.available:hover{background:linear-gradient(135deg,#d4edda,#f8fff8);transform:scale(1.02)}.slot.booked{background:linear-gradient(135deg,#ffeaea,#fff);border:1px solid #e74c3c;border:1px solid var(--error-color);color:#e74c3c;color:var(--error-color);cursor:not-allowed}.slot.disabled{background:#f8f9fa;border:1px solid #dee2e6;color:#6c757d;cursor:not-allowed}.booked-indicator{display:block;font-size:.7rem;font-weight:700;letter-spacing:.5px;margin-top:.25rem;text-transform:uppercase}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalSlideIn .3s ease;background:#fff;background:var(--background-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 8px 25px #0003;box-shadow:var(--shadow-heavy);max-height:90vh;max-width:600px;overflow-y:auto;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1.5rem 2rem}.modal-header h3{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:1.5rem;margin:0}.close-btn{background:none;border:none;border-radius:50%;color:#7f8c8d;color:var(--text-secondary);cursor:pointer;font-size:1.5rem;padding:.5rem;transition:all .3s ease;transition:var(--transition)}.close-btn:hover{color:#2c3e50;color:var(--primary-color)}.booking-details,.close-btn:hover{background:#f8f9fa;background:var(--background-secondary)}.booking-details{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);padding:1.5rem 2rem}.booking-form{padding:2rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#2c3e50;color:var(--primary-color);font-size:.9rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{background:#fff;background:var(--background-primary);border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);font-size:1rem;padding:.75rem;transition:all .3s ease;transition:var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3498db;border-color:var(--accent-color);box-shadow:0 0 0 3px #3498db1a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-actions{border-top:1px solid #e9ecef;border-top:1px solid var(--border-color);display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem}.btn-cancel,.btn-submit{border:none;border-radius:8px;border-radius:var(--border-radius);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease;transition:var(--transition)}.btn-cancel{background:#f8f9fa;background:var(--background-secondary);border:1px solid #e9ecef;border:1px solid var(--border-color);color:#7f8c8d;color:var(--text-secondary)}.btn-cancel:hover{background:#e9ecef;background:var(--border-color);color:#2c3e50;color:var(--text-primary)}.btn-submit{background:linear-gradient(135deg,#3498db,#2980b9);background:linear-gradient(135deg,var(--accent-color),#2980b9);color:#fff}.btn-submit:hover{box-shadow:0 4px 12px #00000026;box-shadow:var(--shadow-medium);transform:translateY(-1px)}.booking-management{background:#fff;background:var(--background-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);padding:2rem}.booking-management h2{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:2.2rem;margin-bottom:2rem;text-align:center}.bookings-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.booking-card{background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);padding:1.5rem;transition:all .3s ease;transition:var(--transition)}.booking-card:hover{box-shadow:0 4px 12px #00000026;box-shadow:var(--shadow-medium);transform:translateY(-2px)}.booking-header h4{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;margin:0}.status{font-weight:600;padding:.25rem .75rem}.status.confirmed{background:#d4edda;color:#155724}.status.pending{background:#fff3cd;color:#856404}.status.cancelled{background:#f8d7da;color:#721c24}.booking-details p{color:#2c3e50;color:var(--text-primary);margin-bottom:.5rem}.booking-details strong{color:#2c3e50;color:var(--primary-color);font-weight:600}@media (max-width:768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.app-header h1{font-size:1.5rem}.main-nav{gap:.25rem;justify-content:center}.nav-btn{min-width:60px;padding:.5rem .75rem}.nav-label{font-size:.7rem}.content-container{padding:0 1rem}.stats-grid{gap:1rem}.dashboard-sections,.halls-grid,.stats-grid{grid-template-columns:1fr}.calendar-grid{gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.bookings-list,.form-row{grid-template-columns:1fr}.modal-content{margin:1rem;width:95%}.booking-form{padding:1rem}.form-actions{flex-direction:column}}@media (max-width:480px){.app-header h1{font-size:1.2rem}.nav-btn{min-width:50px;padding:.4rem .6rem}.nav-icon{font-size:1rem}.nav-label{font-size:.65rem}.calendar-grid{grid-template-columns:1fr}.stat-card{padding:1.5rem}.stat-value{font-size:2rem}}@media print{.app-header,.connection-status,.main-nav{display:none}.app-main{padding:0}.content-container{max-width:none;padding:0}.booking-management,.dashboard,.hall-booking-calendar,.page{border:1px solid #ccc;box-shadow:none;page-break-inside:avoid}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #3498db;outline:2px solid var(--accent-color);outline-offset:2px}@media (prefers-contrast:high){:root{--border-color:#000;--text-secondary:#000}}.calendar-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.calendar-header h3{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:1.5rem;margin:0}.month-navigation{align-items:center;display:flex;gap:1rem}.month-nav-btn{background:linear-gradient(135deg,#3498db,#2980b9);background:linear-gradient(135deg,var(--accent-color),#2980b9);border:none;border-radius:8px;border-radius:var(--border-radius);color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease;transition:var(--transition)}.month-nav-btn:hover{box-shadow:0 4px 12px #00000026;box-shadow:var(--shadow-medium);transform:translateY(-2px)}.month-nav-btn:active{transform:translateY(0)}.current-month{color:#2c3e50;color:var(--primary-color);font-size:1.1rem;font-weight:600;min-width:180px;text-align:center}@media (max-width:768px){.calendar-header{flex-direction:column;text-align:center}.month-navigation{justify-content:center}.month-nav-btn{font-size:.8rem;padding:.5rem 1rem}.current-month{font-size:1rem;min-width:150px}}.features{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.feature-tag{background:linear-gradient(135deg,#3498db,#3498db);background:linear-gradient(135deg,var(--accent-color),#3498db);border-radius:15px;color:#fff;font-size:.75rem;white-space:nowrap}.feature-tag:nth-child(2n){background:linear-gradient(135deg,#27ae60,#2ecc71);background:linear-gradient(135deg,var(--success-color),#2ecc71)}.hall-card{display:flex;flex-direction:column;justify-content:space-between;min-height:200px}.hall-card h4{margin-bottom:.5rem}.hall-card p{color:#7f8c8d;color:var(--text-secondary);flex-grow:1;font-size:.9rem;line-height:1.4;margin-bottom:1rem}.calendar-container{background:#fff;border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);overflow:hidden}.calendar-weekdays{background:#2c3e50;background:var(--primary-color);color:#fff;display:grid;grid-template-columns:repeat(7,1fr)}.weekday-header{font-size:.9rem;font-weight:600;padding:1rem;text-align:center}.calendar-grid{grid-gap:1px;background:#e9ecef;background:var(--border-color);display:grid;gap:1px;grid-template-columns:repeat(7,1fr)}.calendar-empty{background:#f8f9fa;min-height:120px}.calendar-date{background:#fff;display:flex;flex-direction:column;min-height:120px;padding:.5rem}.calendar-date.today .date-header{align-items:center;background:#3498db;background:var(--accent-color);border-radius:50%;color:#fff;display:flex;font-weight:700;height:30px;justify-content:center;width:30px}.calendar-date.past{background:#f8f9fa;color:#6c757d}.date-header{font-size:.9rem;font-weight:600;margin-bottom:.5rem}.slots{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.slot{border-radius:4px;cursor:pointer;font-size:.7rem;padding:.25rem;text-align:center;transition:all .3s ease;transition:var(--transition)}.slot span{display:block;line-height:1.2}@media (max-width:768px){.calendar-date{min-height:80px}.slot{font-size:.6rem;padding:.2rem}}.booking-actions{border-top:1px solid #e9ecef;border-top:1px solid var(--border-color);display:flex;gap:1rem;margin-top:1rem;padding-top:1rem}.btn-download,.btn-edit{border:none;border-radius:8px;border-radius:var(--border-radius);cursor:pointer;flex:1 1;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease;transition:var(--transition)}.btn-edit{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.btn-edit:hover{box-shadow:0 4px 15px #3498db4d;transform:translateY(-2px)}.btn-download{background:linear-gradient(135deg,#27ae60,#229954);color:#fff}.btn-download:hover{box-shadow:0 4px 15px #27ae604d;transform:translateY(-2px)}@media (max-width:768px){.booking-actions{flex-direction:column}.btn-download,.btn-edit{font-size:.8rem;padding:.6rem 1rem}}.analytics-dashboard{background:#fff;background:var(--background-primary);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);padding:2rem}.analytics-dashboard h2{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:2.2rem;margin-bottom:2rem;text-align:center}.filters-section{background:#f8f9fa;background:var(--background-secondary);border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);margin-bottom:2rem;padding:2rem}.filters-section h3{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;margin-bottom:1.5rem}.filters-grid{grid-gap:1rem;gap:1rem;margin-bottom:1.5rem}.filter-group{gap:.5rem}.filter-group label{color:#2c3e50;color:var(--primary-color)}.filter-group input,.filter-group select{border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:1rem;transition:all .3s ease;transition:var(--transition)}.filter-group input:focus,.filter-group select:focus{border-color:#3498db;border-color:var(--accent-color);box-shadow:0 0 0 3px #3498db1a}.filter-actions{gap:1rem;justify-content:flex-end}.btn-export,.btn-reset{border:none;border-radius:8px;border-radius:var(--border-radius);cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease;transition:var(--transition)}.btn-reset{background:#7f8c8d;background:var(--text-secondary);color:#fff}.btn-export{background:linear-gradient(135deg,#27ae60,#2ecc71);background:linear-gradient(135deg,var(--success-color),#2ecc71);color:#fff}.btn-export:hover,.btn-reset:hover{box-shadow:0 4px 12px #00000026;box-shadow:var(--shadow-medium);transform:translateY(-2px)}.metrics-overview{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.metric-card{background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);overflow:hidden;padding:2rem;position:relative;text-align:center;transition:all .3s ease;transition:var(--transition)}.metric-card:before{background:linear-gradient(90deg,#3498db,#27ae60);background:linear-gradient(90deg,var(--accent-color),var(--success-color));content:"";height:4px;left:0;position:absolute;right:0;top:0}.metric-card:hover{box-shadow:0 4px 12px #00000026;box-shadow:var(--shadow-medium);transform:translateY(-4px)}.metric-card h4{color:#7f8c8d;color:var(--text-secondary);font-size:.9rem;font-weight:600;letter-spacing:1px;margin-bottom:1rem;text-transform:uppercase}.metric-value{color:#2c3e50;color:var(--primary-color);font-family:Inter,sans-serif;font-size:2rem;font-weight:700}.analytics-sections{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:2rem}.analytics-section{background:#fff;background:var(--background-primary);border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);padding:2rem}.analytics-section h3{border-bottom:2px solid #3498db;border-bottom:2px solid var(--accent-color);color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:1.3rem;margin-bottom:1.5rem;padding-bottom:.5rem}.hall-analytics{display:flex;flex-direction:column;gap:1rem}.hall-metric{background:#f8f9fa;background:var(--background-secondary);border-left:3px solid #3498db;border-left:3px solid var(--accent-color);border-radius:8px;border-radius:var(--border-radius);padding:1rem}.hall-metric h4{color:#2c3e50;color:var(--primary-color);margin-bottom:.5rem}.hall-metric p{color:#7f8c8d;color:var(--text-secondary);font-size:.9rem;margin:.25rem 0}.status-breakdown{display:flex;flex-direction:column;gap:2rem}.status-group h4{color:#2c3e50;color:var(--primary-color);margin-bottom:1rem}.status-item{align-items:center;border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:.5rem 0}.payment-badge,.status-badge{border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.payment-badge.paid,.status-badge.confirmed{background:#27ae60;background:var(--success-color)}.status-badge.cancelled{background:#e74c3c;background:var(--error-color)}.status-badge.completed{background:#3498db;background:var(--accent-color)}.payment-badge.pending{background:#e74c3c;background:var(--error-color)}.payment-badge.partial{background:#f39c12;background:var(--warning-color)}.bookings-table-section{background:#fff;background:var(--background-primary);border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);padding:2rem}.bookings-table-section h3{color:#2c3e50;color:var(--primary-color);font-family:Playfair Display,serif;font-size:1.3rem;margin-bottom:1.5rem}.table-container{overflow-x:auto}.bookings-table{border-collapse:collapse;border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 4px #0000001a;box-shadow:var(--shadow-light);overflow:hidden;width:100%}.bookings-table th{background:#2c3e50;background:var(--primary-color);color:#fff;font-size:.9rem;font-weight:600;padding:1rem;text-align:left}.bookings-table td{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);font-size:.9rem;padding:1rem}.bookings-table tbody tr:hover{background:#f8f9fa;background:var(--background-secondary)}.bookings-table .status{border-radius:15px;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}@media (max-width:768px){.analytics-dashboard{padding:1rem}.filters-grid{grid-template-columns:1fr}.filter-actions{flex-direction:column}.metrics-overview{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.analytics-sections{grid-template-columns:1fr}.bookings-table{font-size:.8rem}.bookings-table td,.bookings-table th{padding:.5rem}}.booking-header{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.booking-header,.status-controls{align-items:center;display:flex}.status-dropdown{border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:700;letter-spacing:.5px;min-width:120px;padding:.5rem 1rem;text-align:center;text-transform:uppercase;transition:all .3s ease;transition:var(--transition)}.status-dropdown.status-confirmed{background:linear-gradient(135deg,#27ae60,#2ecc71)}.status-dropdown.status-completed{animation:completedPulse 2s infinite;background:linear-gradient(135deg,#e74c3c,#c0392b)}.status-dropdown.status-cancelled{background:linear-gradient(135deg,#95a5a6,#7f8c8d)}.status-dropdown.status-pending{background:linear-gradient(135deg,#f39c12,#e67e22)}.status-dropdown.status-in-progress{background:linear-gradient(135deg,#3498db,#2980b9)}.status-dropdown:focus{outline:3px solid #ffffff4d;transform:scale(1.05)}.status-dropdown option{background:#fff;color:#333;font-weight:400;letter-spacing:normal;text-transform:none}.status{border-radius:20px;color:#fff;font-size:.8rem;font-weight:700;letter-spacing:.5px;padding:.5rem 1rem;text-transform:uppercase}.status.confirmed{background:linear-gradient(135deg,#27ae60,#2ecc71)}.status.completed{animation:completedPulse 2s infinite;background:linear-gradient(135deg,#e74c3c,#c0392b)}.status.cancelled{background:linear-gradient(135deg,#95a5a6,#7f8c8d)}.status.pending{background:linear-gradient(135deg,#f39c12,#e67e22)}.status.in-progress{background:linear-gradient(135deg,#3498db,#2980b9)}@keyframes completedPulse{0%{box-shadow:0 0 0 0 #e74c3cb3}70%{box-shadow:0 0 0 10px #e74c3c00}to{box-shadow:0 0 0 0 #e74c3c00}}@media (max-width:768px){.booking-header{flex-direction:column;gap:1rem;text-align:center}.status-dropdown{font-size:.7rem;min-width:100px}}.header-nav{gap:2rem}.header-nav,.user-info{align-items:center;display:flex}.user-info{border-right:1px solid #fff3;gap:1rem;margin-right:1rem;padding-right:1rem}.user-name{color:#fff;font-size:.9rem;font-weight:500}.user-role{border-radius:15px;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.user-role.super_admin{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff}.user-role.admin{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.logout-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:.8rem;padding:.5rem 1rem;transition:all .3s ease}.logout-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.user-info-banner{background:linear-gradient(135deg,#e3f2fd,#fff);border:1px solid #3498db;border-radius:10px;margin-bottom:2rem;padding:1.5rem}.user-details{display:flex;flex-wrap:wrap;gap:2rem}.user-details p{color:#2c3e50;font-size:.9rem;margin:0}.role-badge{border-radius:15px;color:#fff}.role-badge.super_admin{background:linear-gradient(135deg,#f39c12,#e67e22)}.role-badge.admin{background:linear-gradient(135deg,#3498db,#2980b9)}.admin-notice{background:linear-gradient(135deg,#fff3cd,#fffacd);border:1px solid #ffc107;margin-bottom:1.5rem;text-align:center}.admin-notice p{color:#856404;font-weight:500;margin:0}.restricted-access{background:linear-gradient(135deg,#ffeaea,#fff);border:2px solid #e74c3c;border-radius:15px;margin:2rem 0;padding:4rem 2rem;text-align:center}.restricted-access h2{color:#e74c3c;font-size:2rem;margin-bottom:1rem}.restricted-access p{color:#7f8c8d;font-size:1.1rem;margin-bottom:.5rem}@media (max-width:768px){.header-nav{flex-direction:column;gap:1rem}.user-info{border-bottom:1px solid #fff3;border-right:none;margin-right:0;padding-bottom:1rem;padding-right:0}.user-details{flex-direction:column;gap:.5rem}}@media (max-width:480px){.user-info{flex-direction:column;gap:.5rem;text-align:center}.user-name{font-size:.8rem}.logout-btn{font-size:.7rem;padding:.4rem .8rem}}.advanced-search-container{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:2rem;overflow:hidden}.main-search-bar{background:linear-gradient(135deg,#f8fafc,#fff);border-bottom:1px solid #e2e8f0;display:flex;gap:1rem;padding:1.5rem}.search-input-wrapper{align-items:center;display:flex;flex:1 1;position:relative}.search-icon{color:#6b7280;font-size:1.2rem;left:1rem;position:absolute;z-index:1}.main-search-input{background:#fff;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;padding:1rem 3rem;transition:all .3s ease;width:100%}.main-search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none;transform:translateY(-1px)}.search-spinner{animation:spin 1s linear infinite;border:2px solid #e2e8f0;border-top-color:#3b82f6;height:16px;right:3rem;width:16px}.clear-search-btn,.search-spinner{border-radius:50%;position:absolute}.clear-search-btn{align-items:center;background:#f3f4f6;color:#6b7280;display:flex;font-size:.8rem;height:24px;justify-content:center;right:1rem;transition:all .2s ease;width:24px}.clear-search-btn:hover{background:#e5e7eb;color:#374151}.advanced-filter-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:1rem 1.5rem;position:relative;transition:all .3s ease;white-space:nowrap}.advanced-filter-btn:hover{box-shadow:0 8px 20px #3b82f64d;transform:translateY(-2px)}.advanced-filter-btn.active{background:linear-gradient(135deg,#1d4ed8,#1e40af)}.filter-badge{background:#ef4444;border:2px solid #fff;border-radius:50%;height:12px;position:absolute;right:-4px;top:-4px;width:12px}.advanced-filters-panel{animation:slideDown .3s ease-out;background:#f8fafc;border-top:1px solid #e2e8f0;padding:2rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filters-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.filter-group{display:flex;flex-direction:column}.filter-group label{color:#374151;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.filter-group input,.filter-group select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;padding:.75rem;transition:all .2s ease}.filter-group input:focus,.filter-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.filter-actions{align-items:center;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;padding-top:1.5rem}.clear-filters-btn{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.clear-filters-btn:hover{box-shadow:0 6px 16px #ef44444d;transform:translateY(-2px)}.results-info{align-items:center;display:flex;gap:1rem}.results-text{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#6b7280;font-weight:500;padding:.75rem 1rem}.active-filters-tags{align-items:center;background:#f1f5f9;border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:.75rem;padding:1.5rem}.filters-label{color:#374151;font-size:.9rem;font-weight:600}.filter-tag{align-items:center;animation:fadeIn .3s ease-out;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:20px;color:#fff;display:flex;font-size:.8rem;font-weight:500;gap:.5rem;padding:.5rem .75rem}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.filter-tag button{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.7rem;height:18px;justify-content:center;transition:all .2s ease;width:18px}.filter-tag button:hover{background:#ffffff4d;transform:scale(1.1)}.enhanced-edit-modal{max-height:90vh;max-width:1000px;overflow-y:auto}.enhanced-form .form-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.enhanced-form .form-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem}.enhanced-form .form-section.full-width{grid-column:1/-1}.enhanced-form .form-section h4{align-items:center;border-bottom:2px solid #e2e8f0;color:#1f2937;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem}.enhanced-form .form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.status-selector{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-top:.5rem}.status-option{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;padding:1rem .75rem;text-align:center;transition:all .2s ease}.status-option:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.status-option.selected{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.status-icon{font-size:1.5rem;margin-bottom:.25rem}.status-label{color:#374151;font-size:.85rem;font-weight:500}.balance-display{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;margin-top:.5rem;padding:1rem}.balance-amount{color:#1f2937;font-size:1.25rem;font-weight:700}.balance-status{align-items:center;display:flex}.paid-badge{background:linear-gradient(135deg,#10b981,#059669)}.paid-badge,.pending-badge{align-items:center;border-radius:20px;color:#fff;display:flex;font-size:.8rem;font-weight:600;gap:.25rem;padding:.25rem .75rem}.pending-badge{background:linear-gradient(135deg,#f59e0b,#d97706)}.enhanced-submit{background:linear-gradient(135deg,#10b981,#059669)!important}.enhanced-submit:hover:not(:disabled){box-shadow:0 8px 20px #10b9814d!important}.spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.bookings-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.bookings-header h2{color:#1f2937;font-size:2rem;font-weight:700;margin:0}.enhanced-booking-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:1.5rem;overflow:hidden;transition:all .3s ease}.enhanced-booking-card:hover{border-color:#3b82f6;box-shadow:0 12px 24px #00000026;transform:translateY(-4px)}.enhanced-booking-card .booking-header{align-items:flex-start;display:flex;justify-content:space-between;padding:1.5rem 1.5rem 0}.enhanced-booking-card .customer-info h4{color:#1f2937;font-size:1.25rem;font-weight:700;margin:0 0 .5rem}.enhanced-booking-card .customer-email,.enhanced-booking-card .customer-phone{color:#6b7280;display:block;font-size:.85rem;margin-bottom:.25rem}.enhanced-booking-card .booking-actions{display:flex;flex-shrink:0;gap:.5rem}.enhanced-booking-card .btn-delete,.enhanced-booking-card .btn-download,.enhanced-booking-card .btn-edit{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.enhanced-booking-card .btn-edit{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.enhanced-booking-card .btn-edit:hover{box-shadow:0 4px 12px #3b82f64d;transform:scale(1.1)}.enhanced-booking-card .btn-delete{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.enhanced-booking-card .btn-delete:hover{box-shadow:0 4px 12px #ef44444d;transform:scale(1.1)}.enhanced-booking-card .btn-download{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.enhanced-booking-card .btn-download:hover{box-shadow:0 4px 12px #8b5cf64d;transform:scale(1.1)}.booking-details-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr;padding:1rem 1.5rem 0}.detail-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:.5rem 0}.detail-item:last-child{border-bottom:none}.detail-label{color:#6b7280;font-size:.9rem;font-weight:600}.detail-value{color:#1f2937;font-weight:500;text-align:right}.booking-financial{background:#f8fafc;margin:1rem 0 0;padding:1rem 1.5rem 0}.amount-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.amount-row:last-child{margin-bottom:0}.amount-label{color:#374151;font-size:.9rem;font-weight:600}.amount-value{color:#1f2937;font-size:1rem;font-weight:700}.balance-row{border-top:2px solid #e2e8f0;margin-top:.5rem;padding-top:.5rem}.balance-paid{color:#059669!important}.balance-pending{color:#dc2626!important}.booking-status-section{align-items:center;background:#f1f5f9;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.status-badge{align-items:center;border-radius:20px;display:flex;gap:.25rem;padding:.5rem 1rem;text-transform:capitalize}.status-pending{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.status-confirmed{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.status-in_progress{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.status-completed{background:linear-gradient(135deg,#059669,#047857);color:#fff}.status-cancelled{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.booking-id{background:#6b72801a;border-radius:6px;color:#6b7280;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.booking-meta{background:#f8fafc;border-top:1px solid #e2e8f0;color:#6b7280;font-size:.8rem;padding:.5rem 1.5rem}.booking-notes{background:#fef3c7;border-top:1px solid #f59e0b;color:#92400e;font-size:.9rem;padding:1rem 1.5rem}.booking-notes strong{color:#78350f}.no-bookings{background:#fff;border:2px dashed #e2e8f0;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:4rem 2rem;text-align:center}.no-bookings-icon{font-size:4rem;margin-bottom:1rem}.no-bookings h3{color:#374151;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.no-bookings p{color:#6b7280;font-size:1.1rem;margin-bottom:2rem}.clear-search-btn{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:10px;color:#fff;cursor:pointer;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.clear-search-btn:hover{box-shadow:0 8px 20px #ef44444d;transform:translateY(-2px)}.enhanced-form .form-group input.error,.enhanced-form .form-group select.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.enhanced-form .error-text{color:#ef4444;display:block;font-size:.8rem;margin-top:.25rem}@media (max-width:768px){.main-search-bar{flex-direction:column;gap:1rem}.advanced-filter-btn{justify-content:center}.filters-grid{grid-template-columns:1fr}.filter-actions{align-items:stretch;flex-direction:column;gap:1rem}.active-filters-tags{align-items:flex-start;flex-direction:column}.booking-details-grid,.enhanced-form .form-grid,.enhanced-form .form-row{grid-template-columns:1fr}.status-selector{grid-template-columns:repeat(2,1fr)}.enhanced-booking-card .booking-header{flex-direction:column;gap:1rem}.enhanced-booking-card .booking-actions{justify-content:center}}@media (max-width:480px){.advanced-search-container{border-radius:0;margin:0 -1rem 2rem}.active-filters-tags,.advanced-filters-panel,.main-search-bar{padding:1rem}.enhanced-edit-modal{margin:1rem;max-width:none}.status-selector{grid-template-columns:1fr}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.role-badge{border-radius:12px;font-size:.8rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.role-badge.super_admin{background:linear-gradient(135deg,#f7971e,#ffd200);color:#fff}.role-badge.admin{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.admin-notice{background:#e0f2fe;border:1px solid #0288d1;border-radius:8px;color:#01579b;font-weight:500;margin-bottom:1rem;padding:1rem}.customers-management,.halls-management,.payments-management{background:#f8fafc;min-height:100vh;padding:2rem}.customers-header,.halls-header,.payments-header{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 12px #0000001a;display:flex;justify-content:space-between;margin-bottom:2rem;padding:2rem}.customers-header h2,.halls-header h2,.payments-header h2{align-items:center;color:#1f2937;display:flex;font-size:2rem;font-weight:700;gap:.5rem;margin:0}.header-actions{gap:1rem}.btn-primary{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-primary:hover{box-shadow:0 8px 20px #3b82f64d;transform:translateY(-2px)}.btn-secondary{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:10px;color:#374151;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-secondary:hover{background:#f3f4f6;border-color:#d1d5db;transform:translateY(-1px)}.customer-stats-grid,.hall-stats-grid,.payment-stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.stat-card{align-items:center;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 12px #0000001a;display:flex;gap:1.5rem;padding:2rem;transition:all .3s ease}.stat-card:hover{box-shadow:0 12px 24px #00000026;transform:translateY(-4px)}.stat-icon{align-items:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;display:flex;font-size:3rem;justify-content:center;padding:1rem}.stat-info h3{color:#6b7280;font-size:.9rem;font-weight:600;letter-spacing:.5px;margin:0 0 .5rem;text-transform:uppercase}.stat-value{color:#1f2937;font-size:2rem;font-weight:800;margin-bottom:.5rem}.stat-trend{align-items:center;color:#059669;display:flex;font-size:.85rem;font-weight:500;gap:.25rem}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:3rem}.feature-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 12px #0000001a;overflow:hidden;padding:2.5rem;position:relative;transition:all .3s ease}.feature-card:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899);content:"";height:4px;left:0;position:absolute;right:0;top:0}.feature-card:hover{box-shadow:0 20px 40px #00000026;transform:translateY(-6px)}.feature-icon{display:block;font-size:3rem;margin-bottom:1.5rem}.feature-card h3{color:#1f2937;font-size:1.5rem;font-weight:700;margin-bottom:1rem}.feature-card p{color:#6b7280;line-height:1.6;margin-bottom:1.5rem}.feature-card ul{list-style:none;margin:0;padding:0}.feature-card li{align-items:center;color:#374151;display:flex;font-weight:500;gap:.5rem;padding:.5rem 0}.halls-showcase{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 12px #0000001a;margin-bottom:2rem;padding:3rem}.halls-showcase h3{color:#1f2937;font-size:1.8rem;font-weight:700;margin-bottom:2rem;text-align:center}.halls-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.hall-card{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 8px 20px #0000001a;overflow:hidden;transition:all .3s ease}.hall-card:hover{box-shadow:0 20px 40px #00000026;transform:translateY(-8px)}.hall-image{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;height:200px;justify-content:center;position:relative}.hall-placeholder{color:#fff;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));font-size:4rem}.hall-rating{background:#ffffffe6;border-radius:20px;color:#374151;font-weight:600;padding:.5rem 1rem;position:absolute;right:1rem;top:1rem}.hall-details{padding:2rem}.hall-details h4{color:#1f2937;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.capacity{color:#6b7280;font-weight:500;margin-bottom:1rem}.features-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.feature-tag{background:linear-gradient(135deg,#e0f2fe,#f0f9ff);border:1px solid #0284c7;border-radius:12px;color:#0369a1;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.hall-stats{color:#059669;font-size:.9rem;font-weight:500}.payment-methods{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 12px #0000001a;margin-bottom:2rem;padding:3rem}.payment-methods h3{color:#1f2937;font-size:1.8rem;font-weight:700;margin-bottom:2rem;text-align:center}.methods-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.method-card{background:linear-gradient(135deg,#f8fafc,#fff);border:2px solid #e2e8f0;border-radius:12px;padding:2rem;text-align:center;transition:all .3s ease}.method-card:hover{border-color:#3b82f6;box-shadow:0 8px 20px #3b82f626;transform:translateY(-4px)}.method-icon{display:block;font-size:3rem;margin-bottom:1rem}.method-card h4{color:#1f2937;font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.method-card p{color:#6b7280;margin-bottom:1rem}.method-fee{background:#dcfce7;border-radius:20px;color:#166534;font-size:.9rem;font-weight:600;padding:.5rem 1rem}.outstanding-payments{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 12px #0000001a;padding:3rem}.outstanding-payments h3{color:#1f2937;font-size:1.8rem;font-weight:700;margin-bottom:2rem}.outstanding-list{display:flex;flex-direction:column;gap:1rem}.outstanding-item{align-items:center;background:#f8fafc;border-left:4px solid #e5e7eb;border-radius:12px;display:flex;justify-content:space-between;padding:1.5rem;transition:all .3s ease}.outstanding-item.overdue{background:#fef2f2;border-left-color:#ef4444}.outstanding-item.due{background:#fffbeb;border-left-color:#f59e0b}.outstanding-item.today{background:#ecfdf5;border-left-color:#10b981}.customer-info{display:flex;flex-direction:column;gap:.25rem}.customer-info strong{color:#1f2937;font-weight:600}.amount{color:#059669;font-size:1.1rem;font-weight:700}.payment-status{align-items:center;display:flex;flex-direction:column;gap:.25rem}.status-badge{border-radius:12px;font-size:.8rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.status-badge.overdue{background:#fecaca;color:#dc2626}.status-badge.due{background:#fed7aa;color:#ea580c}.status-badge.today{background:#bbf7d0;color:#059669}.days{color:#6b7280;font-size:.8rem}.actions{display:flex;gap:.5rem}.btn-small{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.8rem;padding:.5rem 1rem;transition:all .2s ease}.btn-small:hover{background:#f3f4f6;border-color:#9ca3af}@media (max-width:768px){.customers-management,.halls-management,.payments-management{padding:1rem}.customers-header,.halls-header,.payments-header{align-items:stretch;flex-direction:column;gap:1rem}.header-actions{flex-direction:column}.customer-stats-grid,.features-grid,.hall-stats-grid,.halls-grid,.payment-stats-grid{grid-template-columns:1fr}.methods-grid{grid-template-columns:repeat(2,1fr)}.outstanding-item{align-items:stretch;flex-direction:column;gap:1rem}.stat-card{flex-direction:column;text-align:center}}@media (max-width:480px){.methods-grid{grid-template-columns:1fr}.feature-card{padding:1.5rem}.halls-showcase,.outstanding-payments,.payment-methods{padding:2rem}}.payments-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:20px}.payments-header h2{color:#2c3e50;flex-shrink:0;font-size:24px;margin:0}.header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.header-actions .btn-primary,.header-actions .btn-secondary{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;height:36px;min-width:fit-content;padding:8px 12px;transition:all .2s ease;white-space:nowrap}.header-actions .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 4px #667eea4d;color:#fff}.header-actions .btn-primary:hover{box-shadow:0 4px 8px #667eea66;transform:translateY(-1px)}.header-actions .btn-secondary{background:#f8f9fa;border:1px solid #dee2e6;color:#495057}.header-actions .btn-secondary:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}@media (max-width:768px){.payments-header{align-items:flex-start;flex-direction:column}.header-actions{justify-content:flex-start;width:100%}.header-actions .btn-primary,.header-actions .btn-secondary{font-size:11px;height:32px;padding:6px 10px}}@media (max-width:480px){.header-actions{flex-direction:column;width:100%}.header-actions .btn-primary,.header-actions .btn-secondary{justify-content:center;width:100%}}.outstanding-item .actions{align-items:center;display:flex;gap:4px}.outstanding-item .btn-small{background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;color:#495057;cursor:pointer;font-size:10px;min-width:fit-content;padding:4px 8px;transition:all .2s ease;white-space:nowrap}.outstanding-item .btn-small:hover{background:#e9ecef;border-color:#adb5bd}.payment-stats-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:25px}.stat-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.stat-card .stat-info h3{color:#6c757d;font-size:13px;font-weight:500;margin-bottom:8px}.stat-card .stat-value{color:#2c3e50;font-size:22px;font-weight:700;margin-bottom:4px}.stat-card .stat-trend{color:#28a745;font-size:11px;font-weight:500}