body{background-color:#111827;color:#fff;font-family:sans-serif;margin:0}.login-container{align-items:center;display:flex;height:100vh;justify-content:center}.login-form{background:#1f2937;border-radius:8px;box-shadow:0 4px 6px #0000004d;max-width:400px;padding:2rem;text-align:center;width:100%}.login-form h2{color:#f59e0b;font-size:24px;margin-bottom:1.5rem}.input-group{margin-bottom:1rem;text-align:left}.input-group label{color:#9ca3af;display:block;margin-bottom:.5rem}.input-group input{background-color:#374151;border:1px solid #374151;border-radius:4px;box-sizing:border-box;color:#fff;padding:.75rem;width:100%}.input-group input:focus{border-color:#f59e0b;outline:none}.login-button{background-color:#14b8a6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem;transition:background-color .3s ease;width:100%}.login-button:hover{background-color:#0d9488}.auth-link{color:#9ca3af;font-size:.9rem;margin-top:1rem}.link{color:#14b8a6;cursor:pointer;margin-left:.25rem;text-decoration:underline}.link:hover{color:#0d9488}.error-message{color:#dc3545;font-size:14px;margin:10px 0;text-align:center}.dashboard-container{max-width:1200px;padding:2rem}.dashboard-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:2rem}.dashboard-section{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.dashboard-section h2{color:#333;font-size:1.5rem;margin-bottom:1.5rem}.dashboard-actions{display:flex;flex-direction:column;gap:1rem}.dashboard-button{background-color:#4caf50;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 20px;transition:background-color .3s}.dashboard-button:hover{background-color:#45a049}.logout-button{background-color:#f44336;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;margin-top:2rem;padding:12px 24px;transition:background-color .3s}.logout-button:hover{background-color:#d32f2f}.loading{align-items:center;color:#666;display:flex;font-size:1.2rem;height:100vh;justify-content:center}.login-button:disabled{background-color:#6c757d;cursor:not-allowed}.container{margin:0 auto;max-width:448px;min-height:100vh;padding:16px}.text-center{text-align:center}.header{margin-bottom:24px}.footer{color:#6b7280;margin-top:24px}.title{font-size:36px;font-weight:700}.city-name{color:#f59e0b;font-size:20px;font-weight:500;margin-top:4px}.date-display{color:#9ca3af;font-size:18px}.next-prayer-time{color:#14b8a6;font-size:24px;font-weight:600;margin-top:8px}.prayer-cards-container{display:flex;flex-direction:column;gap:12px}.prayer-card{align-items:center;background-color:#1f2937;border-radius:8px;display:flex;justify-content:space-between;padding:16px}.prayer-card.is-next{background-color:#14b8a6}.prayer-card-info{align-items:center;display:flex}.prayer-card-icon{height:24px;margin-right:16px;width:24px}.prayer-name{font-size:20px;font-weight:700}.prayer-arabic-name{font-family:serif;font-size:18px}.prayer-time{font-family:monospace;font-size:24px}.error-screen,.loading-screen{align-items:center;color:#fff;display:flex;justify-content:center;min-height:100vh}.error-screen{color:#ef4444}.mosque-list-container{margin:0 auto;max-width:1200px;padding:2rem}.mosque-list-header{align-items:center;border-bottom:2px solid #374151;display:flex;justify-content:space-between;margin-bottom:2.5rem;padding-bottom:1rem}.mosque-list-header h2{align-items:center;color:#f59e0b;display:flex;font-size:2rem;font-weight:600;gap:.5rem;margin:0}.mosque-list-header h2:before{content:"🕌";font-size:1.5rem}.header-title{display:flex;flex-direction:column;gap:.5rem}.mosque-count{align-self:flex-start;background:#37415180;border-radius:20px;color:#9ca3af;font-size:.9rem;font-weight:400;padding:.25rem .75rem}.mosque-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:1rem}.mosque-card{background:linear-gradient(135deg,#1f2937,#111827);border:1px solid #374151;border-radius:12px;box-shadow:0 8px 25px #0006;overflow:hidden;padding:0;position:relative;transition:all .3s ease}.mosque-card:before{background:linear-gradient(90deg,#14b8a6,#f59e0b);content:"";height:4px;left:0;position:absolute;right:0;top:0}.mosque-card:hover{border-color:#14b8a6;box-shadow:0 15px 35px #00000080;transform:translateY(-5px)}.mosque-card-header{align-items:flex-start;display:flex;justify-content:space-between;padding:1.5rem 1.5rem 0}.mosque-card h3{color:#14b8a6;font-size:1.4rem;font-weight:600;line-height:1.3;margin:0}.mosque-info{padding:1rem 1.5rem}.mosque-info p{align-items:center;color:#d1d5db;display:flex;font-size:.95rem;gap:.5rem;line-height:1.5;margin:.75rem 0}.mosque-info p strong{color:#f59e0b;font-weight:500;min-width:80px}.mosque-info a{color:#14b8a6;text-decoration:none;transition:color .2s ease}.mosque-info a:hover{color:#0d9488;text-decoration:underline}.mosque-card-footer{background:#11182780;border-top:1px solid #374151;padding:1rem 1.5rem}.mosque-card-footer small{color:#9ca3af;font-size:.85rem}.mosque-actions{align-items:center;display:flex;gap:.5rem}.edit-button{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:6px;box-shadow:0 2px 4px #f59e0b4d;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 12px;transition:all .2s ease}.edit-button:hover{box-shadow:0 4px 8px #f59e0b66;transform:translateY(-1px)}.delete-button{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:6px;box-shadow:0 2px 4px #ef44444d;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;justify-content:center;padding:8px 12px;transition:all .2s ease}.delete-button:hover{box-shadow:0 4px 8px #ef444466;transform:translateY(-1px)}.add-mosque-button{align-items:center;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:8px;box-shadow:0 4px 12px #14b8a64d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;padding:12px 24px;transition:all .2s ease}.add-mosque-button:hover{box-shadow:0 6px 20px #14b8a666;transform:translateY(-2px)}.no-mosques{background:linear-gradient(135deg,#1f2937,#111827);border:2px dashed #374151;border-radius:12px;margin:2rem 0;padding:4rem 2rem;text-align:center}.no-mosques p{margin-bottom:2rem}.error,.loading,.no-mosques p{color:#9ca3af;font-size:1.1rem}.error,.loading{padding:3rem;text-align:center}.retry-button{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:8px;font-size:1rem;margin-top:1rem;padding:12px 24px;transition:all .2s ease}.retry-button:hover{box-shadow:0 4px 12px #f59e0b4d;transform:translateY(-1px)}.add-mosque-container{margin:0 auto;max-width:600px;padding:2rem}.add-mosque-form{background:#1f2937;border-radius:8px;box-shadow:0 4px 6px #0000004d;padding:2rem}.add-mosque-form h2{color:#f59e0b;text-align:center}.add-mosque-form h2,.form-group{margin-bottom:1.5rem}.form-row{align-items:flex-start;display:flex;gap:1rem;width:100%}.form-row .form-group{flex:1 1;min-width:0}.form-group label{color:#9ca3af;display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group textarea{background-color:#374151;border:1px solid #374151;border-radius:4px;box-sizing:border-box;color:#fff;font-family:inherit;padding:.75rem;width:100%}.form-row .form-group input{box-sizing:border-box;width:100%}.form-group textarea{min-height:100px;resize:vertical}.form-group input:focus,.form-group textarea:focus{border-color:#14b8a6;outline:none}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.submit-button{background-color:#14b8a6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 24px;transition:background-color .3s}.submit-button:hover{background-color:#0d9488}.submit-button:disabled{background-color:#6b7280;cursor:not-allowed}.cancel-button{background-color:#6b7280;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 24px;transition:background-color .3s}.cancel-button:hover{background-color:#4b5563}.dashboard-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.dashboard-header h1{color:#f59e0b;margin:0}.back-button{background-color:#6b7280;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:10px 20px;transition:background-color .3s}.back-button:hover{background-color:#4b5563}.empty-state{color:#9ca3af;text-align:center}.empty-state h3{color:#6b7280;margin-bottom:1rem}.primary-button{background-color:#14b8a6;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;padding:12px 24px;text-decoration:none;transition:background-color .3s}.primary-button:hover{background-color:#0d9488}.dashboard-layout{display:flex;flex-direction:column;min-height:100vh}.professional-header{background:linear-gradient(135deg,#1f2937,#111827);border-bottom:3px solid #14b8a6;box-shadow:0 4px 6px #0000004d;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-container{gap:2rem;justify-content:space-between;margin:0 auto;max-width:1400px;padding:1rem 2rem}.header-container,.header-left{align-items:center;display:flex}.logo{align-items:flex-start;display:flex;flex-direction:column}.logo h1{color:#f59e0b;font-size:1.8rem;font-weight:700;letter-spacing:1px;margin:0}.logo-subtitle{color:#9ca3af;font-size:.8rem;font-weight:300;margin-top:-4px}.header-nav,.nav-item{align-items:center;display:flex;gap:.5rem}.nav-item{background:#0000;border:none;border-radius:8px;color:#9ca3af;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.25rem;position:relative;transition:all .3s ease}.nav-item:hover{background:#14b8a61a;color:#14b8a6;transform:translateY(-1px)}.nav-item.active{background:#14b8a6;box-shadow:0 2px 4px #14b8a64d;color:#fff}.nav-item.active:after{background:#f59e0b;border-radius:50%;bottom:-3px;content:"";height:6px;left:50%;position:absolute;transform:translateX(-50%);width:6px}.nav-icon{font-size:1.1rem}.header-right{align-items:center;display:flex;gap:1.5rem}.user-info{align-items:flex-end;display:flex;flex-direction:column;text-align:right}.user-name{color:#f3f4f6;font-size:.95rem;font-weight:600}.user-role{color:#9ca3af;font-size:.8rem;margin-top:-2px}.header-actions{align-items:center;display:flex;gap:1rem}.mobile-menu-toggle{background:#0000;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:none;font-size:1.5rem;padding:.5rem;transition:color .3s ease}.mobile-menu-toggle:hover{color:#14b8a6}.logout-btn{align-items:center;background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.75rem 1.25rem;transition:all .3s ease}.logout-btn:hover{background:#dc2626;box-shadow:0 4px 8px #ef44444d;transform:translateY(-1px)}.logout-icon{font-size:1rem}.mobile-menu{background:#1f2937;border-top:1px solid #374151;display:none;flex-direction:column;gap:.5rem;padding:1rem}.mobile-nav-item{align-items:center;background:#0000;border:none;border-radius:8px;color:#9ca3af;cursor:pointer;display:flex;font-size:1rem;gap:.75rem;padding:1rem;text-align:left;transition:all .3s ease;width:100%}.mobile-nav-item:hover{background:#14b8a61a;color:#14b8a6}.mobile-nav-item.active{background:#14b8a6;color:#fff}.dashboard-main{background:#111827;flex:1 1;padding:2rem 0}.dashboard-container{margin:0 auto;max-width:1400px;padding:0 2rem}.welcome-section{background:linear-gradient(135deg,#1f2937,#374151);border:1px solid #374151;border-radius:12px;margin-bottom:3rem;padding:2rem;text-align:center}.welcome-section h2{color:#f59e0b;font-size:2rem;font-weight:600;margin-bottom:1rem}.welcome-section p{color:#9ca3af;font-size:1.1rem;line-height:1.6;margin:0 auto;max-width:600px}.dashboard-stats{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:2rem}.stat-card{background:linear-gradient(135deg,#1f2937,#111827);border:1px solid #374151;border-radius:12px;overflow:hidden;padding:2rem;position:relative;text-align:center}.stat-card:before{background:linear-gradient(90deg,#14b8a6,#f59e0b);content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:hover{border-color:#14b8a6;box-shadow:0 8px 25px #0000004d;transform:translateY(-4px)}.stat-card h3{color:#14b8a6;font-size:1.4rem;font-weight:600;margin-bottom:1rem}.stat-card p{color:#9ca3af;line-height:1.5;margin-bottom:1.5rem}.stat-card .dashboard-button{background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.875rem 1.5rem;transition:all .3s ease;width:100%}.stat-card .dashboard-button:hover{background:linear-gradient(135deg,#0d9488,#0f766e);box-shadow:0 4px 12px #14b8a64d;transform:translateY(-2px)}.prayer-times-content,.profile-content{background:#1f2937;border:1px solid #374151;border-radius:12px;padding:2rem;text-align:center}.prayer-times-content h2,.profile-content h2{color:#f59e0b;margin-bottom:1rem}.prayer-times-content p,.profile-content p{color:#9ca3af;font-size:1.1rem}.admin-content{margin:0 auto;max-width:1200px;padding:2rem}.admin-content h2{color:#2c3e50;font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.admin-section{background:#fff;border:1px solid #e1e8ed;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:2rem}.admin-section p{color:#666;font-size:1.1rem;margin-bottom:2rem;text-align:center}.admin-actions{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:1.5rem}.admin-actions .action-button{align-items:center;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;justify-content:center;padding:1rem 1.5rem;transition:all .3s ease}.admin-actions .action-button:hover{box-shadow:0 8px 25px #14b8a64d;transform:translateY(-2px)}.section-title{color:#2c3e50;font-size:1.8rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.dashboard-main-layout{display:flex;min-height:calc(100vh - 80px)}.dashboard-content{border-right:1px solid #e2e8f0;flex:1 1;padding:2rem}.dashboard-right-sidebar{background:linear-gradient(135deg,#1f2937,#111827);border-left:3px solid #14b8a6;box-shadow:-2px 0 10px #0000004d;overflow-y:auto;padding:2rem;width:320px}.sidebar-section{border-bottom:1px solid #374151;margin-bottom:2rem;padding-bottom:1.5rem}.sidebar-section:last-child{border-bottom:none}.sidebar-title{align-items:center;color:#f3f4f6;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin-bottom:1rem}.notification-item{align-items:flex-start;border-radius:8px;display:flex;gap:.75rem;margin-bottom:.5rem;padding:.75rem;transition:background-color .2s ease}.notification-item:hover{background:#f8fafc}.notification-icon{flex-shrink:0;font-size:1.2rem}.notification-content{flex:1 1}.notification-text{color:#334155;font-size:.9rem;line-height:1.4;margin:0 0 .25rem}.notification-time{color:#64748b;font-size:.8rem}.activity-item{align-items:flex-start;border-radius:8px;display:flex;gap:.75rem;margin-bottom:.5rem;padding:.75rem;transition:background-color .2s ease}.activity-item:hover{background:#f8fafc}.activity-icon{flex-shrink:0;font-size:1.2rem}.activity-content{flex:1 1}.activity-text{color:#334155;font-size:.9rem;line-height:1.4;margin:0 0 .25rem}.activity-time{color:#64748b;font-size:.8rem}.quick-action-buttons{display:flex;flex-direction:column;gap:.5rem}.quick-action-btn{align-items:center;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;text-align:left;transition:all .2s ease}.quick-action-btn:hover{box-shadow:0 4px 12px #14b8a64d;transform:translateY(-1px)}.quick-action-btn .btn-icon{font-size:1rem}@media (max-width:768px){.header-container{flex-wrap:wrap;padding:1rem}.header-nav{display:none}.mobile-menu-toggle{display:block}.mobile-menu{display:flex}.user-info{display:none}.logo h1{font-size:1.5rem}.dashboard-main-layout{flex-direction:column}.dashboard-right-sidebar{border-left:none;border-top:3px solid #14b8a6;box-shadow:0 -2px 10px #0000004d;width:100%}.dashboard-content{border-right:none}.dashboard-stats{grid-template-columns:1fr}.welcome-section{padding:1.5rem}.welcome-section h2{font-size:1.5rem}.mosque-list-container{padding:1rem}.mosque-list-header{flex-direction:column;gap:1rem;text-align:center}.mosque-list-header h2{font-size:1.5rem}.mosque-grid{gap:1.5rem;grid-template-columns:1fr}.mosque-card{margin:0}.mosque-card-header{padding:1rem 1rem 0}.mosque-card h3{font-size:1.2rem}.mosque-info{padding:.75rem 1rem}.mosque-info p{align-items:flex-start;flex-direction:column;gap:.25rem}.mosque-info p strong{min-width:auto}.add-mosque-button{justify-content:center;width:100%}.no-mosques{padding:2rem 1rem}}@media (max-width:480px){.header-container{padding:.75rem;.status-button{background:none;border:none;border-radius:50%;cursor:pointer;font-size:1.2rem;padding:.25rem;transition:all .2s ease}.status-button:hover{background-color:#0000001a;transform:scale(1.1)}.status-button.active{color:#22c55e}.status-button.inactive{color:#ef4444}.status-badge{border-radius:1rem;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.status-badge.active{background-color:#dcfce7;border:1px solid #bbf7d0;color:#166534}.status-badge.inactive{background-color:#fef2f2;border:1px solid #fecaca;color:#991b1b}.mosque-card.inactive{border-left:4px solid #ef4444;opacity:.7}.mosque-card.inactive .mosque-card-header h3,.mosque-card.inactive .mosque-card-header h4{color:#6b7280}.status-indicator{align-items:center;display:flex;gap:.5rem;margin-bottom:.75rem}.mosque-code{background-color:#f3f4f6;border-radius:.25rem;color:#374151;font-family:Courier New,monospace;font-weight:600;padding:.125rem .375rem}.mosque-title-section{align-items:flex-start;display:flex;flex-direction:column}.mosque-date{color:#6b7280;display:block;font-size:.75rem;font-style:italic;margin-top:.25rem}.subscription-status{border-radius:.375rem;display:flex;flex-direction:column;font-size:.9em;font-weight:600;gap:5px;padding:.25rem .5rem}.status-line{gap:5px}.expiry-line,.status-line{align-items:center;display:flex}.expiry-line{color:#666;font-size:.85em;margin-left:20px}.subscription-status.active{background-color:#dcfce7;color:#166534}.subscription-status.inactive{background-color:#fee2e2;color:#991b1b}.subscription-status.expired{background-color:#fef3c7;color:#92400e}.subscription-status.trial{background-color:#e0e7ff;color:#3730a3}.subscription-expiry{color:#6b7280;font-size:.75rem;font-style:italic}}.dashboard-main{padding:1rem 0}.dashboard-container{padding:0 1rem}.stat-card{padding:1.5rem}.mosque-list-container{padding:.5rem}.mosque-list-header h2{font-size:1.3rem}.mosque-card-header{padding:.75rem .75rem 0}.mosque-info{padding:.5rem .75rem}.mosque-card-footer{padding:.75rem}.mosque-actions{flex-direction:column;gap:.25rem}.delete-button,.edit-button{justify-content:center;width:100%}}.statistics-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#1f2937;border-left:4px solid #0000;border-radius:8px;box-shadow:0 4px 6px #0000004d;display:flex;gap:1rem;padding:1.5rem;transition:all .3s ease}.stat-card:hover{box-shadow:0 8px 25px #0006;transform:translateY(-2px)}.stat-card.primary{border-left-color:#14b8a6}.stat-card.secondary{border-left-color:#f59e0b}.stat-card.quaternary{border-left-color:#6366f1}.stat-icon{align-items:center;background:#ffffff1a;border-radius:50%;display:flex;font-size:24px;height:50px;justify-content:center;width:50px}.stat-info h3{color:#fff;font-size:24px;font-weight:700;margin:0}.stat-info p{color:#9ca3af;font-size:14px;font-weight:500;margin:4px 0 0}.quick-actions{background:#1f293780;border:1px solid #374151;border-radius:8px;box-shadow:0 4px 6px #0000004d;padding:1.5rem}.quick-actions h3{color:#f59e0b;font-size:1.25rem;font-weight:600;margin:0 0 1.5rem}.action-buttons{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.action-button{background-color:#14b8a6;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;font-weight:500;padding:12px 24px;text-align:center;text-decoration:none;transition:background-color .3s}.action-button:hover{background-color:#0d9488}.action-button:focus{box-shadow:0 0 0 3px #14b8a64d;outline:none}.dashboard-layout-content{display:flex;gap:2rem;margin:0 auto;max-width:1400px;padding:0 2rem}.dashboard-main-content{flex:1 1;min-width:0}.dashboard-sidebar{flex-shrink:0;width:320px}.dashboard-sidebar .quick-actions{position:-webkit-sticky;position:sticky;top:2rem}.dashboard-sidebar .action-buttons{display:flex;flex-direction:column;gap:.75rem}.dashboard-sidebar .action-button{justify-content:flex-start;text-align:left;width:100%}@media (max-width:1024px){.dashboard-sidebar{width:280px}}@media (max-width:768px){.dashboard-layout-content{flex-direction:column;gap:1.5rem;padding:0 1rem}.dashboard-sidebar{display:none}.statistics-grid{gap:1rem;grid-template-columns:1fr}.stat-card{padding:1.25rem}}.dashboard-footer{background:#1f2937;border-top:1px solid #374151;margin-top:auto;padding:1rem 0}.footer-content{margin:0 auto;max-width:1400px;padding:0 2rem;text-align:center}.footer-user-info{color:#9ca3af;font-size:.9rem}.footer-user-info strong{color:#14b8a6;font-weight:600}.success-message{align-items:center;background-color:#d1fae5;border:1px solid #10b981;border-radius:6px;color:#065f46;display:flex;font-weight:500;gap:8px;margin-bottom:20px;padding:12px 16px}.success-message:before{content:"✅";font-size:16px}.field-error{color:#dc2626;display:block;font-size:.875rem;font-weight:500;margin-top:4px}.form-group input.error,.form-group textarea.error{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.form-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin:20px 0;padding:20px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.section-header h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.geo-button{align-items:center;background:linear-gradient(135deg,#14b8a6,#0d9488);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.geo-button:hover:not(:disabled){background:linear-gradient(135deg,#0d9488,#0f766e);box-shadow:0 4px 12px #14b8a64d;transform:translateY(-1px)}.geo-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.geo-help{color:#64748b;font-size:.875rem;font-style:italic;line-height:1.4;margin:12px 0 0}@media (max-width:768px){.section-header{align-items:flex-start;flex-direction:column;gap:12px}.geo-button{justify-content:center;width:100%}.form-section{padding:16px}}@media (max-width:480px){.form-row{flex-direction:column;gap:0}}@media (max-width:768px){.statistics-grid{gap:16px;grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-button{min-width:auto;width:100%}.stat-card{padding:20px}.stat-icon{height:50px;width:50px}.stat-icon,.stat-info h3{font-size:24px}.footer-content{padding:0 1rem}.footer-user-info{font-size:.8rem}}.admin-subscriptions{margin:0 auto;max-width:100%;padding:20px}.admin-subscriptions-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:30px}.admin-subscriptions-header h2{color:#1e293b;font-size:1.8rem;font-weight:600;margin:0}.admin-subscriptions-controls{align-items:center;display:flex;flex-wrap:wrap;gap:20px}.search-box{position:relative}.search-input{border:2px solid #e2e8f0;border-radius:8px;font-size:14px;padding:10px 16px;transition:all .2s ease;width:300px}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.filter-buttons{display:flex;gap:8px}.filter-btn{background:#fff;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.filter-btn:hover{background:#f8fafc;border-color:#3b82f6}.filter-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.subscriptions-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.subscriptions-stats .stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;padding:20px}.subscriptions-stats .stat-icon{align-items:center;background:#f1f5f9;border-radius:12px;display:flex;font-size:2rem;height:60px;justify-content:center;width:60px}.subscriptions-stats .stat-info h3{color:#1e293b;font-size:1.8rem;font-weight:700;margin:0}.subscriptions-stats .stat-info p{color:#64748b;font-size:.9rem;font-weight:500;margin:4px 0 0}.admin-subscriptions-error,.admin-subscriptions-loading{padding:60px 20px;text-align:center}.loading-spinner{border:4px solid #e2e8f0;border-top-color:#3b82f6;margin:0 auto 20px}.retry-button{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background .2s ease}.retry-button:hover{background:#2563eb}.no-subscriptions{color:#64748b;font-size:1.1rem;padding:60px 20px}.subscriptions-table{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.table-header{background:#f8fafc;border-bottom:2px solid #e2e8f0;color:#374151;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.table-header,.table-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:2fr 2fr 1fr 1.5fr 2fr 2fr;padding:20px}.table-row{border-bottom:1px solid #e2e8f0;transition:background .2s ease}.table-row:hover{background:#f8fafc}.table-row:last-child{border-bottom:none}.client-info h4,.mosque-info h4{color:#1e293b;font-size:1rem;font-weight:600;margin:0 0 4px}.client-info p,.mosque-info p{color:#64748b;font-size:.85rem;margin:2px 0}.status-badge,.type-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:.8rem;font-weight:600;gap:4px;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.status-active{background:#dcfce7;color:#166534}.status-inactive{background:#fee2e2;color:#991b1b}.status-expired{background:#fef3c7;color:#92400e}.status-trial{background:#e0e7ff;color:#3730a3}.type-monthly{background:#dbeafe;color:#1e40af}.type-yearly{background:#d1fae5;color:#065f46}.type-trial{background:#f3e8ff;color:#6b21a8}.expiring-warning{color:#f59e0b}.expired-warning,.expiring-warning{font-size:.75rem;font-weight:600;margin-top:4px}.expired-warning{color:#dc2626}.dates-info p{color:#64748b;font-size:.8rem;margin:2px 0}.dates-info strong{color:#374151}.action-buttons{display:flex;flex-direction:column;gap:6px}.btn-activate,.btn-convert,.btn-deactivate,.btn-extend{border:none;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:500;padding:6px 12px;text-align:center;transition:all .2s ease}.btn-activate{background:#dcfce7;color:#166534}.btn-activate:hover{background:#bbf7d0}.btn-deactivate{background:#fee2e2;color:#991b1b}.btn-deactivate:hover{background:#fecaca}.btn-extend{background:#dbeafe;color:#1e40af}.btn-extend:hover{background:#bfdbfe}.btn-convert{background:#f3e8ff;color:#6b21a8}.btn-convert:hover{background:#e9d5ff}@media (max-width:1200px){.table-header,.table-row{grid-template-columns:1.5fr 1.5fr 1fr 1fr 1.5fr 1.5fr}}@media (max-width:968px){.admin-subscriptions-header{align-items:flex-start;flex-direction:column}.admin-subscriptions-controls{justify-content:space-between;width:100%}.search-input{width:250px}.subscriptions-table{overflow-x:auto}.table-header,.table-row{min-width:800px}}@media (max-width:768px){.search-input{width:200px}.filter-buttons{flex-wrap:wrap}.subscriptions-stats{grid-template-columns:1fr}.action-buttons{flex-direction:row;flex-wrap:wrap}}@media (max-width:480px){.admin-subscriptions{padding:10px}.admin-subscriptions-controls{align-items:stretch;flex-direction:column}.search-input{width:100%}.filter-buttons{justify-content:center}}.subscription-management{margin:0 auto;max-width:1200px;padding:2rem}.subscription-header{margin-bottom:2rem;text-align:center}.subscription-header h2{color:#f59e0b;font-size:2rem;margin-bottom:.5rem}.subscription-header p{color:#9ca3af;font-size:1.1rem}.error-container,.loading-container{padding:3rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #374151;border-radius:50%;border-top-color:#f59e0b;height:40px;margin:0 auto 1rem;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-container h3{color:#ef4444;margin-bottom:1rem}.retry-btn{background-color:#f59e0b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s}.retry-btn:hover{background-color:#d97706}.no-subscriptions{padding:3rem;text-align:center}.empty-state{background:#1f2937;border:2px dashed #374151;border-radius:12px;padding:3rem}.empty-icon{display:block;font-size:4rem;margin-bottom:1rem}.empty-state h3{color:#f59e0b;margin-bottom:.5rem}.empty-state p{color:#9ca3af}.subscriptions-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));margin-bottom:2rem}.subscription-card{background:#1f2937;border:1px solid #374151;border-radius:12px;padding:1.5rem;transition:transform .2s,box-shadow .2s}.subscription-card:hover{box-shadow:0 8px 25px #0000004d;transform:translateY(-2px)}.subscription-header-card{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.mosque-info h3{color:#f59e0b;font-size:1.25rem;margin:0 0 .5rem}.mosque-details{display:flex;flex-direction:column;gap:.25rem;margin:0}.mosque-code{color:#9ca3af;font-size:.9rem;font-weight:500}.mosque-city{color:#6b7280;font-size:.9rem}.status-badge{border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:.5rem 1rem;text-transform:uppercase}.subscription-details{margin-bottom:1.5rem}.detail-row{align-items:center;border-bottom:1px solid #374151;display:flex;justify-content:space-between;padding:.5rem 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#9ca3af;font-weight:500}.detail-value{color:#f3f4f6;font-weight:600}.detail-value.expiring{color:#f59e0b}.detail-value.expired{color:#ef4444}.warning-text{color:#f59e0b}.error-text,.warning-text{font-size:.85rem;font-weight:500}.error-text{color:#ef4444}.subscription-actions{display:flex;flex-wrap:wrap;gap:.75rem}.action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;flex:1 1;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-width:120px;padding:.75rem 1rem;transition:all .2s}.upgrade-btn{background-color:#10b981;color:#fff}.upgrade-btn:hover{background-color:#059669}.renew-btn{background-color:#3b82f6;color:#fff}.renew-btn:hover{background-color:#2563eb}.details-btn{background-color:#6b7280;color:#fff}.details-btn:hover{background-color:#4b5563}.btn-icon{font-size:1rem}.subscription-extended-details{background:#111827;border-radius:8px;border-top:2px solid #374151;margin-top:1.5rem;padding:1.5rem}.subscription-extended-details h4{color:#f59e0b;font-size:1.1rem;margin:0 0 1rem}.extended-detail-grid{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.5rem}.extended-detail{background:#1f2937;border-radius:4px;display:flex;justify-content:space-between;padding:.5rem}.extended-detail strong{color:#9ca3af}.extended-detail span{color:#f3f4f6;font-family:monospace;font-size:.9rem}.future-features{background:#0f172a;border-left:4px solid #f59e0b;border-radius:6px;padding:1rem}.future-features h5{color:#f59e0b;font-size:1rem;margin:0 0 .75rem}.future-features ul{color:#9ca3af;margin:0;padding-left:1.5rem}.future-features li{font-size:.9rem;margin-bottom:.5rem}.subscription-summary{background:#1f2937;border:1px solid #374151;border-radius:12px;padding:2rem}.subscription-summary h3{color:#f59e0b;font-size:1.5rem;margin:0 0 1.5rem;text-align:center}.summary-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.summary-stat{background:#111827;border:1px solid #374151;border-radius:8px;padding:1rem;text-align:center}.stat-number{color:#f59e0b;display:block;font-size:2rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:#9ca3af;font-size:.9rem;font-weight:500}@media (max-width:768px){.subscription-management{padding:1rem}.subscriptions-grid{gap:1rem;grid-template-columns:1fr}.subscription-header h2{font-size:1.5rem}.subscription-actions{flex-direction:column}.action-btn{flex:none;min-width:auto}.summary-stats{gap:.75rem;grid-template-columns:repeat(2,1fr)}.stat-number{font-size:1.5rem}.subscription-header-card{align-items:flex-start;flex-direction:column;gap:1rem}.status-badge{align-self:flex-start}}
/*# sourceMappingURL=main.55c4abc8.css.map*/