.language-selector{display:flex;align-items:center;gap:8px;font-size:14px}.language-selector label{color:#a8b3cf;font-weight:500}.lang-dropdown{padding:6px 12px;border:1px solid #243047;border-radius:6px;background:#182235;color:#eaf0ff;cursor:pointer;font-size:14px;transition:border-color .2s}.lang-dropdown:hover{border-color:#33ff8a}.lang-dropdown:focus{outline:none;border-color:#33ff8a;box-shadow:0 0 0 3px #33ff8a1a}.login-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:#0b0f14;padding:20px}.login-card{background:#121824;padding:40px;border-radius:16px;box-shadow:0 10px 40px #00000080;border:1px solid #243047;width:100%;max-width:400px}.login-title{font-size:32px;font-weight:700;color:#eaf0ff;text-align:center;margin-bottom:8px}.login-subtitle{font-size:16px;color:#a8b3cf;text-align:center;margin-bottom:30px}.error-message{background-color:#ff4d4d26;color:#ff4d4d;padding:12px 16px;border-radius:8px;border-left:4px solid #FF4D4D;margin-bottom:20px;font-size:14px;font-weight:500;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:600;color:#eaf0ff;margin-bottom:8px}.form-group input{width:100%;padding:12px;border:1px solid #243047;border-radius:8px;font-size:16px;background-color:#182235;color:#eaf0ff;transition:border-color .3s}.form-group input::placeholder{color:#7683a5}.form-group input:focus{outline:none;border-color:#33ff8a}.form-group input:disabled{background-color:#121824;cursor:not-allowed;opacity:.5}.login-button{width:100%;padding:14px;background-color:#33ff8a;color:#0b0f14;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s}.login-button:hover:not(:disabled){background-color:#20d86e}.login-button:disabled{background-color:#243047;color:#7683a5;cursor:not-allowed}.login-hint{margin-top:30px;padding:15px;background-color:#182235;border-radius:8px;font-size:13px;color:#a8b3cf;text-align:center;border:1px solid #243047}.login-hint p{margin:4px 0}.landing-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:#0b0f14;padding:20px}.landing-content{text-align:center;color:#eaf0ff;max-width:800px}.landing-content h1{font-size:3.5em;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.5);color:#eaf0ff}.tagline{font-size:1.3em;opacity:.95;margin-bottom:40px;color:#a8b3cf}.cta-section{margin:40px 0}.download-btn{padding:18px 48px;font-size:1.2em;background:#33ff8a;color:#0b0f14;border:none;border-radius:50px;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 15px #33ff8a4d}.download-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #33ff8a66;background:#20d86e}.download-note{margin-top:15px;font-size:.9em;opacity:.9;color:#a8b3cf}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:30px;margin-top:60px}.feature{background:#121824cc;border:1px solid #243047;padding:30px 20px;border-radius:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .2s}.feature:hover{transform:translateY(-5px);background:#1a2838e6;border-color:#33ff8a}.feature .icon{font-size:3em;display:block;margin-bottom:15px;color:#33ff8a}.feature h3{margin:10px 0;font-size:1.3em;color:#eaf0ff}.feature p{opacity:.9;font-size:.95em;color:#a8b3cf}.dashboard-container{min-height:100vh;background-color:#0b0f14;padding:20px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:15px}.dashboard-header h1{font-size:28px;color:#eaf0ff;font-weight:600}.refresh-button{background-color:#2ee59d;color:#0b0f14;border-color:#2ee59d}.logout-button{background-color:#ff4d4d;color:#eaf0ff;border-color:#ff4d4d;margin-left:auto}.logout-button:hover{background-color:#e63946;border-color:#e63946}.modal-content{background:#121824;padding:30px;border-radius:12px;border:1px solid #243047;max-width:600px;width:90%;max-height:80vh;overflow-y:auto}.modal-content h2{margin-top:0;color:#eaf0ff}.gym-info-display{margin:20px 0}.info-section{margin-bottom:20px;padding:15px;background:#182235;border-radius:8px;border:1px solid #243047}.info-section h3{margin-top:0;color:#3cd6ff;font-size:1.1em}.info-section p{margin:8px 0;color:#a8b3cf}.info-note{color:#ffb020;background:#ffb02026;padding:10px;border-radius:4px;margin:15px 0;border:1px solid rgba(255,176,32,.3)}.btn-close{padding:10px 20px;background:#243047;color:#eaf0ff;border:1px solid #243047;border-radius:6px;cursor:pointer;font-size:14px}.btn-close:hover{background:#182235;border-color:#33ff8a}.dashboard-loading,.dashboard-error{padding:40px 20px;text-align:center}.dashboard-error{background-color:#121824;border-radius:8px;border:1px solid #243047;max-width:500px;margin:0 auto}.dashboard-error p{color:#ff4d4d;margin-bottom:20px;font-size:16px}.retry-button{padding:10px 24px;background-color:#2ee59d;color:#0b0f14;border:none;border-radius:6px;cursor:pointer;font-size:14px}.retry-button:hover{background-color:#20d86e}.dashboard-content{max-width:1400px;margin:0 auto}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#121824;border-radius:8px;padding:24px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #33ff8a33;border-color:#33ff8a}.stat-card.highlight{background:linear-gradient(135deg,#33ff8a,#20d86e);color:#0b0f14;border-color:#33ff8a}.stat-card.skeleton{background:linear-gradient(90deg,#121824 25%,#182235,#121824 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;min-height:120px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.stat-label{font-size:14px;color:#a8b3cf;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.stat-card.highlight .stat-label{color:#0b0f14cc}.stat-value{font-size:36px;font-weight:700;color:#eaf0ff;margin-bottom:4px}.stat-card.highlight .stat-value{color:#0b0f14}.stat-caption{font-size:13px;color:#7683a5}.stat-card.highlight .stat-caption{color:#0b0f14b3}.panels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:20px}@media (max-width: 1100px){.panels-grid{grid-template-columns:1fr}}.panel{background:#121824;border-radius:8px;padding:24px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.panel.skeleton{background:linear-gradient(90deg,#121824 25%,#182235,#121824 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;min-height:400px}.panel h2{font-size:20px;color:#eaf0ff;margin-bottom:20px;font-weight:600;border-bottom:2px solid #243047;padding-bottom:10px}.empty-state{text-align:center;padding:60px 20px;color:#7683a5}.empty-state p{margin-bottom:12px;font-size:16px}.empty-icon{font-size:48px;opacity:.5}.checkins-list{display:flex;flex-direction:column;gap:12px}.checkin-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background-color:#182235;border-radius:6px;border-left:4px solid #2EE59D;transition:background-color .2s;gap:12px;flex-wrap:wrap}.checkin-item:hover{background-color:#1a2838}.checkin-user{flex:1;min-width:180px}.user-name{font-weight:600;color:#eaf0ff;margin-bottom:4px}.user-email{font-size:13px;color:#a8b3cf}.checkin-details{flex:1;min-width:140px;text-align:left}.pass-type{font-weight:500;color:#eaf0ff;margin-bottom:4px}.checkin-time{font-size:13px;color:#7683a5}.remaining-badge{padding:4px 12px;background-color:#121824;border:1px solid #243047;border-radius:12px;font-size:12px;font-weight:500;color:#a8b3cf;white-space:nowrap}.alerts-section{display:flex;flex-direction:column;gap:24px}.alert-group h3.alert-title{font-size:16px;color:#eaf0ff;margin-bottom:12px;font-weight:600}.alert-list{display:flex;flex-direction:column;gap:10px}.alert-item{padding:14px;background-color:#182235;border-radius:6px;border-left:4px solid #FFB020;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s}.alert-item:hover{background-color:#1a2838}.alert-item.expiring{border-left-color:#ffb020}.alert-item.low-entries{border-left-color:#ff4d4d}.alert-user{font-weight:600;color:#eaf0ff;flex:1}.alert-meta{display:flex;gap:12px;align-items:center;font-size:13px;color:#a8b3cf}.alert-type{font-weight:500}.alert-date,.alert-count{color:#7683a5}@media (max-width: 768px){.dashboard-container{padding:15px}.dashboard-header{flex-direction:column;align-items:flex-start}.dashboard-header h1{font-size:24px}.nav-buttons{width:100%}.nav-button{flex:1;min-width:100px}.stats-grid,.panels-grid{grid-template-columns:1fr;gap:15px}.checkin-item{flex-direction:column;align-items:flex-start}.alert-item{flex-direction:column;align-items:flex-start;gap:8px}.alert-meta{flex-direction:column;align-items:flex-start;gap:4px}}.scanner-container{min-height:100vh;background-color:#0b0f14;padding:20px}.scanner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#121824;padding:20px;border-radius:12px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.scanner-header h1{font-size:28px;color:#eaf0ff;margin:0}.nav-button{padding:10px 20px;background-color:#33ff8a;color:#0b0f14;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .3s}.scanner-content{max-width:800px;margin:0 auto}.camera-section{background:#121824;border-radius:12px;padding:20px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d;margin-bottom:20px}.camera-placeholder{display:flex;flex-direction:column;align-items:center;gap:15px;padding:60px 20px}.start-button{padding:16px 40px;background-color:#2ee59d;color:#0b0f14;border:none;border-radius:8px;font-size:18px;font-weight:600;cursor:pointer;transition:background-color .3s}.start-button:hover{background-color:#20d86e}.manual-button{padding:12px 30px;background-color:#243047;color:#eaf0ff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .3s}.manual-button:hover{background-color:#182235}.camera-active{display:flex;flex-direction:column;align-items:center;gap:15px}.camera-video{width:100%;max-width:500px;border-radius:8px}.stop-button{padding:12px 30px;background-color:#ff4d4d;color:#eaf0ff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s}.stop-button:hover{background-color:#e63946}.processing{text-align:center;padding:20px;background:#ffb02026;border:1px solid #FFB020;border-radius:8px;font-size:16px;font-weight:600;color:#ffb020;margin-bottom:20px}.error-box{padding:16px;background-color:#ff4d4d26;color:#ff4d4d;border:1px solid #FF4D4D;border-radius:8px;margin-bottom:20px;font-size:14px;font-weight:500}.result-panel{background:#121824;border-radius:12px;padding:30px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.status-valid{border:3px solid #2EE59D}.status-invalid{border:3px solid #FF4D4D}.status-badge{text-align:center;padding:20px;margin-bottom:30px}.status-badge h2{font-size:36px;font-weight:700;margin:0}.status-valid .status-badge h2{color:#2ee59d}.status-invalid .status-badge h2{color:#ff4d4d}.pass-details h3{font-size:18px;color:#eaf0ff;margin:20px 0 15px;border-bottom:2px solid #243047;padding-bottom:10px}.detail-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #243047}.detail-row .label{font-size:14px;color:#a8b3cf;font-weight:500}.detail-row .value{font-size:14px;color:#eaf0ff;font-weight:600}.auto-consumed-notice{background-color:#2ee59d26;color:#2ee59d;border:1px solid rgba(46,229,157,.3);padding:12px;border-radius:8px;margin:20px 0;text-align:center;font-weight:600}.done-button{width:100%;padding:14px;background-color:#33ff8a;color:#0b0f14;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;margin-top:20px;transition:background-color .3s}.done-button:hover{background-color:#20d86e}.invalid-reason{text-align:center;padding:20px 0}.invalid-reason p{font-size:16px;color:#a8b3cf;margin-bottom:10px}.invalid-reason .reason-text{font-size:20px;font-weight:700;color:#ff4d4d;margin-bottom:20px}.history-container{min-height:100vh;background-color:#0b0f14;padding:20px}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#121824;padding:20px;border-radius:12px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.history-header h1{font-size:28px;color:#eaf0ff;margin:0}.loading{text-align:center;padding:40px;font-size:18px;color:#a8b3cf}.empty-state{text-align:center;padding:60px 20px;background:#121824;border-radius:12px;border:1px solid #243047;font-size:18px;color:#7683a5}.history-content{background:#121824;border-radius:12px;padding:20px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d;overflow-x:auto}.history-table{width:100%;border-collapse:collapse}.history-table thead{background-color:#182235}.history-table th{padding:14px;text-align:left;font-size:14px;font-weight:600;color:#eaf0ff;border-bottom:2px solid #243047}.history-table td{padding:14px;font-size:14px;color:#a8b3cf;border-bottom:1px solid #243047}.history-table tbody tr:hover{background-color:#182235}.action-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.action-scan{background-color:#3cd6ff33;color:#3cd6ff;border:1px solid rgba(60,214,255,.3)}.action-consume{background-color:#2ee59d33;color:#2ee59d;border:1px solid rgba(46,229,157,.3)}.createpass-container{min-height:100vh;background-color:#0b0f14;padding:20px}.createpass-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#121824;padding:20px;border-radius:12px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.createpass-header h1{font-size:28px;color:#eaf0ff;margin:0}.nav-buttons{display:flex;gap:10px}.nav-button{padding:10px 20px;background-color:#33ff8a;color:#0b0f14;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.nav-button:hover{background-color:#20d86e}.step-panel{background:#121824;border-radius:12px;padding:30px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d;max-width:800px;margin:0 auto}.step-panel h2{font-size:22px;color:#eaf0ff;margin-bottom:20px}.search-section{margin-bottom:30px}.search-bar{display:flex;gap:10px;margin-bottom:15px}.search-bar input{flex:1;padding:12px;border:1px solid #243047;border-radius:8px;font-size:16px;background-color:#182235;color:#eaf0ff}.search-bar input::placeholder{color:#7683a5}.search-bar button{padding:12px 24px;background-color:#33ff8a;color:#0b0f14;border:none;border-radius:8px;font-size:16px;cursor:pointer}.search-bar button:hover:not(:disabled){background-color:#20d86e}.search-bar button:disabled{background-color:#243047;color:#7683a5;cursor:not-allowed}.new-user-button{padding:10px 20px;background-color:#2ee59d;color:#0b0f14;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.new-user-button:hover{background-color:#20d86e}.new-user-form{background-color:#182235;padding:20px;border-radius:8px;border:1px solid #243047;margin-bottom:20px}.new-user-form h3{font-size:18px;margin-bottom:15px;color:#eaf0ff}.form-group label{display:block;font-size:14px;font-weight:600;margin-bottom:5px;color:#eaf0ff}.form-group input{width:100%;padding:10px;border:1px solid #243047;border-radius:6px;font-size:14px;background-color:#121824;color:#eaf0ff}.users-list{margin-top:20px}.users-list h3{font-size:16px;margin-bottom:15px;color:#a8b3cf}.user-items{display:flex;flex-direction:column;gap:10px}.user-item{padding:15px;border:2px solid #243047;border-radius:8px;cursor:pointer;transition:all .2s;background-color:#182235}.user-item:hover{border-color:#33ff8a;background-color:#1a2838}.user-item-name{font-size:16px;font-weight:600;color:#eaf0ff;margin-bottom:4px}.user-item-email{font-size:14px;color:#a8b3cf}.selected-user-panel{background-color:#33ff8a1a;padding:20px;border-radius:8px;border:2px solid #33FF8A}.selected-user-panel h3{font-size:18px;margin-bottom:10px;color:#eaf0ff}.user-info{margin:15px 0}.user-info p{margin:8px 0;font-size:15px}.temp-password-panel{background-color:#ffb02026;border:2px solid #FFB020;padding:20px;border-radius:8px;margin-bottom:20px}.temp-password-panel h3{font-size:18px;color:#ffb020;margin-bottom:10px}.password-display{display:flex;align-items:center;gap:10px;margin:15px 0}.password-display code{flex:1;background-color:#121824;padding:12px;border-radius:6px;font-size:18px;font-weight:700;color:#eaf0ff;border:1px solid #243047}.copy-button{padding:10px 20px;background-color:#33ff8a;color:#0b0f14;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer}.copy-button:hover{background-color:#20d86e}.temp-password-note{font-size:13px;color:#ffb020;margin-top:10px;font-weight:500}.selected-user-summary{background-color:#182235;padding:15px;border-radius:8px;border:1px solid #243047;margin-bottom:20px}.pass-types-list{display:flex;flex-direction:column;gap:15px;margin-bottom:20px}.pass-type-item{padding:20px;border:2px solid #243047;border-radius:8px;cursor:pointer;transition:all .2s;background-color:#182235}.pass-type-item:hover{border-color:#33ff8a}.pass-type-item.selected{border-color:#33ff8a;background-color:#33ff8a1a}.pass-type-item h3{font-size:18px;color:#eaf0ff;margin-bottom:8px}.pass-type-item p{font-size:14px;color:#a8b3cf;margin-bottom:12px}.pass-type-details{display:flex;gap:15px;font-size:14px;color:#a8b3cf}.pass-type-details .price{margin-left:auto;font-size:18px;font-weight:700;color:#33ff8a}.button-group{display:flex;gap:10px;margin-top:20px}.primary-button{flex:1;padding:14px;background-color:#33ff8a;color:#0b0f14;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer}.primary-button:hover:not(:disabled){background-color:#20d86e}.primary-button:disabled{background-color:#243047;color:#7683a5;cursor:not-allowed}.secondary-button{flex:1;padding:14px;background-color:#243047;color:#eaf0ff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer}.secondary-button:hover{background-color:#182235}.success-panel{background:#121824;border-radius:12px;padding:40px;text-align:center;border:1px solid #243047;box-shadow:0 2px 8px #0000004d;max-width:600px;margin:0 auto}.success-panel h2{font-size:28px;color:#2ee59d;margin-bottom:15px}.success-panel p{font-size:16px;color:#a8b3cf;margin-bottom:30px}.users-container{min-height:100vh;background-color:#0b0f14;padding:20px}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:15px}.users-header h1{font-size:28px;color:#eaf0ff;font-weight:600}.nav-buttons{display:flex;gap:10px;flex-wrap:wrap}.nav-button{padding:10px 20px;background-color:#121824;border:1px solid #243047;border-radius:6px;cursor:pointer;font-size:14px;color:#eaf0ff;transition:all .2s}.nav-button:hover{background-color:#182235;border-color:#33ff8a}.users-controls{background:#121824;padding:20px;border-radius:8px;margin-bottom:20px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.search-form{display:flex;gap:10px;margin-bottom:15px}.search-button{padding:10px 24px;background-color:#33ff8a;color:#0b0f14;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600}.search-button:hover{background-color:#20d86e}.filter-options{display:flex;gap:20px;align-items:center}.filter-checkbox{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer;color:#a8b3cf}.filter-checkbox input[type=checkbox]{cursor:pointer}.refresh-button{padding:8px 16px;background-color:#2ee59d;color:#0b0f14;border:none;border-radius:6px;cursor:pointer;font-size:14px;margin-left:auto}.refresh-button:hover{background-color:#20d86e}.users-stats{display:flex;gap:30px;padding:15px 20px;background:#121824;border-radius:8px;margin-bottom:15px;font-size:14px;color:#a8b3cf;border:1px solid #243047;box-shadow:0 2px 4px #0003}.users-stats strong{color:#eaf0ff;font-weight:600}.loading-state{text-align:center;padding:40px;background:#121824;border-radius:8px;border:1px solid #243047;font-size:16px;color:#a8b3cf}.error-message{padding:15px 20px;background-color:#ff4d4d26;border:1px solid #FF4D4D;border-radius:6px;color:#ff4d4d;margin-bottom:20px}.empty-state{text-align:center;padding:60px 20px;background:#121824;border-radius:8px;border:1px solid #243047;font-size:16px;color:#7683a5}.users-content{background:#121824;border-radius:8px;overflow:hidden;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.users-table{width:100%;border-collapse:collapse}.users-table thead{background-color:#182235}.users-table th{padding:14px;text-align:left;font-size:13px;font-weight:600;color:#eaf0ff;border-bottom:2px solid #243047;text-transform:uppercase;letter-spacing:.5px}.users-table td{padding:14px;font-size:14px;color:#a8b3cf;border-bottom:1px solid #243047}.users-table tbody tr:hover{background-color:#182235}.users-table tbody tr.blocked-row{background-color:#ff4d4d1a}.users-table tbody tr.blocked-row:hover{background-color:#ff4d4d26}.pass-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.pass-badge.active{background-color:#2ee59d33;color:#2ee59d;border:1px solid rgba(46,229,157,.3)}.pass-badge.inactive{background-color:#ff4d4d33;color:#ff4d4d;border:1px solid rgba(255,77,77,.3)}.pass-summary{display:flex;flex-direction:column;gap:5px}.pass-info{font-size:12px;color:#a8b3cf}.pass-detail{color:#7683a5}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.status-badge.active{background-color:#2ee59d33;color:#2ee59d;border:1px solid rgba(46,229,157,.3)}.status-badge.blocked{background-color:#ff4d4d33;color:#ff4d4d;border:1px solid rgba(255,77,77,.3)}.action-button{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:all .2s}.action-button.view{background-color:#3cd6ff;color:#0b0f14}.action-button.view:hover{background-color:#24b7e6}.action-button.warning{background-color:#ffb020;color:#0b0f14}.action-button.warning:hover{background-color:#e6a01c}.action-button.success{background-color:#2ee59d;color:#0b0f14}.action-button.success:hover{background-color:#20d86e}.action-button.danger{background-color:#ff4d4d;color:#eaf0ff}.action-button.danger:hover{background-color:#e63946}.action-button:disabled{background-color:#243047;color:#7683a5;cursor:not-allowed}.action-button.small{padding:6px 12px;font-size:12px}.user-detail-content{display:grid;grid-template-columns:1fr 2fr;gap:20px}@media (max-width: 1200px){.user-detail-content{grid-template-columns:1fr}}.detail-card{background:#121824;border-radius:8px;padding:24px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.detail-card h2{font-size:20px;color:#eaf0ff;margin-bottom:20px;font-weight:600;border-bottom:2px solid #243047;padding-bottom:10px}.detail-grid{display:flex;flex-direction:column;gap:15px;margin-bottom:24px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px;background-color:#182235;border-radius:6px;border:1px solid #243047}.detail-row .label{font-weight:600;color:#a8b3cf;font-size:14px}.detail-row .value{font-size:14px;color:#eaf0ff}.detail-row .value.code{font-family:monospace;font-size:12px;color:#a8b3cf}.action-buttons{display:flex;gap:10px;flex-wrap:wrap}.action-buttons .action-button{flex:1;min-width:150px}.passes-list{display:flex;flex-direction:column;gap:15px}.pass-item{padding:16px;border:1px solid #243047;border-radius:8px;background-color:#182235}.pass-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.pass-item-header h3{font-size:16px;color:#eaf0ff;font-weight:600}.pass-status{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.pass-status.active{background-color:#2ee59d33;color:#2ee59d;border:1px solid rgba(46,229,157,.3)}.pass-status.expired{background-color:#ff4d4d33;color:#ff4d4d;border:1px solid rgba(255,77,77,.3)}.pass-status.depleted{background-color:#ffb02033;color:#ffb020;border:1px solid rgba(255,176,32,.3)}.pass-status.revoked{background-color:#182235;color:#7683a5;border:1px solid #243047}.pass-item-details{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.pass-item-row{display:flex;justify-content:space-between;font-size:13px}.pass-item-row .label{color:#a8b3cf;font-weight:500}.pass-actions{display:flex;gap:8px;margin-top:12px}.pass-item-row .code{font-family:monospace;font-size:11px;color:#7683a5}@media (max-width: 768px){.users-container{padding:15px}.users-header{flex-direction:column;align-items:flex-start}.users-header h1{font-size:24px}.nav-buttons{width:100%}.nav-button{flex:1;min-width:100px}.search-form{flex-direction:column}.filter-options{flex-direction:column;align-items:flex-start;gap:10px}.refresh-button{margin-left:0;width:100%}.users-table{font-size:12px}.users-table th,.users-table td{padding:10px 8px}.user-detail-content{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons .action-button{width:100%}}.pass-management-container{min-height:100vh;background-color:#0b0f14;max-width:1200px;margin:0 auto;padding:20px}.pass-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:15px}.pass-management-header h1{margin:0;font-size:28px;color:#eaf0ff;font-weight:600}.templates-section,.custom-section{margin-bottom:40px;background:#121824;border-radius:8px;padding:20px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.templates-section h2,.custom-section h2{margin-top:0;font-size:20px;color:#eaf0ff;font-weight:600;border-bottom:2px solid #243047;padding-bottom:10px}.templates-list,.custom-list{display:flex;flex-direction:column;gap:20px;margin-top:20px}.template-item,.custom-item{width:100%;border:1px solid #243047;border-radius:6px;padding:15px;background:#182235;transition:all .2s}.template-item:hover,.custom-item:hover{border-color:#33ff8a;background:#1a2838}.template-header,.custom-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.template-header h3,.custom-header-row h3{margin:0;color:#eaf0ff;font-size:1.1em;font-weight:600}.enable-checkbox{display:flex;align-items:center;gap:8px;font-size:.9em;color:#a8b3cf}.enable-checkbox input[type=checkbox]{accent-color:#2EE59D}.template-desc,.custom-item p{color:#a8b3cf;font-size:.9em;margin:10px 0}.offering-info,.custom-info{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid #243047}.offering-info span,.custom-info span{color:#a8b3cf}.custom-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.add-custom-button,.configure-button,.edit-button{padding:8px 16px;background:#2ee59d;color:#0b0f14;border:1px solid #2EE59D;border-radius:6px;cursor:pointer;font-size:.9em;font-weight:500;transition:all .2s}.add-custom-button:hover,.configure-button:hover,.edit-button:hover{background:#20d86e;border-color:#20d86e}.pass-offering-form{max-width:600px;max-height:90vh;overflow-y:auto}.form-section{margin-bottom:25px;padding-bottom:20px;border-bottom:1px solid #243047}.form-section:last-of-type{border-bottom:none}.form-section h3{margin-top:0;margin-bottom:15px;color:#3cd6ff;font-size:1.1em;font-weight:600}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#a8b3cf}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:8px 12px;background:#182235;border:1px solid #243047;border-radius:6px;font-size:14px;color:#eaf0ff;box-sizing:border-box;transition:all .2s}.form-group input[type=text]:focus,.form-group input[type=number]:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#33ff8a;background:#1a2838}.read-only-field{background:#0b0f14!important;border-color:#243047!important;color:#7683a5!important;cursor:not-allowed;opacity:.7}.form-group textarea{resize:vertical;min-height:60px}.form-group input[type=checkbox]{margin-right:8px;accent-color:#2EE59D}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:20px;border-top:1px solid #243047}.primary-button,.secondary-button{padding:10px 20px;border:1px solid;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.primary-button{background:#2ee59d;color:#0b0f14;border-color:#2ee59d}.primary-button:hover:not(:disabled){background:#20d86e;border-color:#20d86e}.primary-button:disabled{background:#243047;color:#7683a5;border-color:#243047;cursor:not-allowed}.secondary-button{background:#121824;color:#eaf0ff;border-color:#243047}.secondary-button:hover{background:#182235;border-color:#33ff8a}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000008c;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#121824;padding:30px;border-radius:12px;border:1px solid #243047;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;color:#eaf0ff}.modal-content h2{margin-top:0;color:#eaf0ff;font-weight:600}.loading-state{text-align:center;padding:40px 20px;color:#a8b3cf;background:#121824;border-radius:8px;border:1px solid #243047}.error-box{background:#121824;border:1px solid #FF4D4D;border-radius:8px;padding:15px;margin-bottom:20px;color:#ff4d4d}.admin-dashboard{padding:30px;max-width:1400px;margin:0 auto;background-color:#0b0f14;min-height:100vh}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.admin-header h1{font-size:2em;color:#eaf0ff;margin:0}.admin-actions{display:flex;gap:10px}.btn-primary{padding:10px 20px;background-color:#3cd6ff;color:#0b0f14;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.btn-primary:hover{background-color:#24b7e6}.btn-logout{padding:10px 20px;background-color:#ff4d4d;color:#eaf0ff;border:none;border-radius:6px;cursor:pointer;font-size:14px}.btn-logout:hover{background-color:#e63946}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:#121824;border-radius:12px;padding:25px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d;text-align:center}.stat-icon{font-size:2.5em;margin-bottom:10px;color:#33ff8a}.stat-value{font-size:2.5em;font-weight:700;color:#eaf0ff;margin-bottom:5px}.stat-label{color:#a8b3cf;font-size:.9em}.recent-gyms{background:#121824;border-radius:12px;padding:25px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.recent-gyms h2{margin-top:0;margin-bottom:20px;color:#eaf0ff}.gyms-list{display:flex;flex-direction:column;gap:15px}.gym-card{display:flex;justify-content:space-between;align-items:center;padding:15px;border:1px solid #243047;border-radius:8px;cursor:pointer;transition:all .2s;background-color:#182235}.gym-card:hover{border-color:#33ff8a;box-shadow:0 2px 8px #33ff8a33}.gym-info h3{margin:0 0 5px;color:#eaf0ff}.gym-slug{color:#a8b3cf;font-size:.9em;margin:0}.status-badge{padding:5px 12px;border-radius:20px;font-size:.85em;font-weight:500}.status-active{background-color:#2ee59d33;color:#2ee59d;border:1px solid rgba(46,229,157,.3)}.status-blocked{background-color:#ff4d4d33;color:#ff4d4d;border:1px solid rgba(255,77,77,.3)}.status-deleted{background-color:#182235;color:#7683a5;border:1px solid #243047}.admin-loading,.admin-error{padding:40px;text-align:center;color:#a8b3cf}.admin-error button{margin-top:20px;padding:10px 20px;background-color:#3cd6ff;color:#0b0f14;border:none;border-radius:6px;cursor:pointer}.admin-gyms{padding:30px;max-width:1600px;margin:0 auto;background-color:#0b0f14;min-height:100vh}.btn-secondary{padding:10px 20px;background-color:#243047;color:#eaf0ff;border:none;border-radius:6px;cursor:pointer;font-size:14px}.btn-secondary:hover{background-color:#182235}.filters{display:flex;gap:15px;margin-bottom:25px}.search-input{flex:1;padding:10px 15px;border:1px solid #243047;border-radius:6px;font-size:14px;background-color:#182235;color:#eaf0ff}.search-input::placeholder{color:#7683a5}.status-filter{padding:10px 15px;border:1px solid #243047;border-radius:6px;font-size:14px;min-width:150px;background-color:#182235;color:#eaf0ff}.gyms-table-container{background:#121824;border-radius:12px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d;overflow:hidden}.gyms-table{width:100%;border-collapse:collapse}.gyms-table thead{background-color:#182235}.gyms-table th{padding:15px;text-align:left;font-weight:600;color:#eaf0ff;border-bottom:2px solid #243047}.gyms-table td{padding:15px;border-bottom:1px solid #243047;color:#a8b3cf}.gyms-table tbody tr:hover{background-color:#182235}.gym-name{font-weight:500;color:#eaf0ff}.gym-slug{color:#a8b3cf;font-family:monospace;font-size:.9em}.sub-status{padding:4px 10px;border-radius:12px;font-size:.85em;font-weight:500}.no-sub{background-color:#182235;color:#7683a5;border:1px solid #243047}.sub-active{background-color:#2ee59d33;color:#2ee59d;border:1px solid rgba(46,229,157,.3)}.sub-trialing{background-color:#3cd6ff33;color:#3cd6ff;border:1px solid rgba(60,214,255,.3)}.sub-past_due{background-color:#ffb02033;color:#ffb020;border:1px solid rgba(255,176,32,.3)}.sub-canceled{background-color:#ff4d4d33;color:#ff4d4d;border:1px solid rgba(255,77,77,.3)}.btn-view{padding:6px 14px;background-color:#3cd6ff;color:#0b0f14;border:none;border-radius:4px;cursor:pointer;font-size:13px}.btn-view:hover{background-color:#24b7e6}.no-results{padding:40px;text-align:center;color:#7683a5}.loading,.error{padding:40px;text-align:center;color:#a8b3cf}.error button{margin-top:20px;padding:10px 20px;background-color:#3cd6ff;color:#0b0f14;border:none;border-radius:6px;cursor:pointer}.admin-gym-detail{padding:30px;max-width:1400px;margin:0 auto;background-color:#0b0f14;min-height:100vh}.header-title{display:flex;flex-direction:column;gap:5px}.header-title h1{margin:0;color:#eaf0ff}.staff-login-path{font-size:.8em;color:#a8b3cf;font-weight:400}.staff-login-path code{background:#182235;padding:4px 8px;border-radius:4px;font-family:monospace;color:#eaf0ff;border:1px solid #243047}.gym-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:30px}.info-card{background:#121824;border-radius:12px;padding:25px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.info-card h3{margin-top:0;margin-bottom:20px;color:#eaf0ff;font-size:1.2em}.info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #243047}.info-row:last-child{border-bottom:none}.info-row .label{color:#a8b3cf;font-weight:500}.info-row .value{color:#eaf0ff}.info-row .value.code{font-family:monospace;font-size:.9em;background:#182235;padding:4px 8px;border-radius:4px;border:1px solid #243047}.info-row a{color:#3cd6ff;text-decoration:none}.info-row a:hover{text-decoration:underline}.no-data{color:#7683a5;font-style:italic}.passes-breakdown{display:flex;flex-direction:column;gap:10px}.pass-type-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #243047}.pass-type-row:last-child{border-bottom:none}.pass-type-row .count{font-weight:600;color:#3cd6ff}.actions-section{background:#121824;border-radius:12px;padding:25px;border:1px solid #243047;box-shadow:0 2px 8px #0000004d}.actions-section h3{margin-top:0;margin-bottom:20px;color:#eaf0ff}.action-buttons{display:flex;gap:15px;flex-wrap:wrap}.btn-danger{padding:12px 24px;background-color:#ff4d4d;color:#eaf0ff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.btn-danger:hover{background-color:#e63946}.btn-danger:disabled{background-color:#243047;color:#7683a5;cursor:not-allowed}.btn-success{padding:12px 24px;background-color:#2ee59d;color:#0b0f14;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.btn-success:hover{background-color:#20d86e}.btn-success:disabled{background-color:#243047;color:#7683a5;cursor:not-allowed}.btn-danger-outline{padding:12px 24px;background-color:#121824;color:#ff4d4d;border:2px solid #FF4D4D;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.btn-danger-outline:hover{background-color:#ff4d4d;color:#eaf0ff}.btn-danger-outline:disabled{opacity:.5;cursor:not-allowed}.btn-edit{padding:8px 16px;background-color:#3cd6ff;color:#0b0f14;border:none;border-radius:4px;cursor:pointer;font-size:14px}.btn-edit:hover{background-color:#24b7e6}.edit-form input{width:100%;padding:8px;margin-bottom:10px;border:1px solid #243047;border-radius:4px;font-size:14px;box-sizing:border-box;background-color:#182235;color:#eaf0ff}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.status-active{background:#2ee59d33;color:#2ee59d;border:1px solid rgba(46,229,157,.3)}.status-pending{background:#ffb02033;color:#ffb020;border:1px solid rgba(255,176,32,.3)}.status-blocked{background:#ff4d4d33;color:#ff4d4d;border:1px solid rgba(255,77,77,.3)}.status-deleted{background:#182235;color:#7683a5;border:1px solid #243047}.sub-status{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize}.sub-active{background:#2ee59d33;color:#2ee59d;border:1px solid rgba(46,229,157,.3)}.sub-trialing{background:#3cd6ff33;color:#3cd6ff;border:1px solid rgba(60,214,255,.3)}.sub-past_due{background:#ffb02033;color:#ffb020;border:1px solid rgba(255,176,32,.3)}.sub-canceled,.sub-cancelled,.sub-unpaid{background:#ff4d4d33;color:#ff4d4d;border:1px solid rgba(255,77,77,.3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0b0f14;color:#eaf0ff}#root{min-height:100vh}
