:root{--ff-primary:#212529;--ff-primary-soft:rgba(33,37,41,.14);--ff-danger-soft:rgba(220,53,69,.14);--ff-success-soft:rgba(25,135,84,.14);--ff-text:#f8f9fa;--ff-muted:#adb5bd;--ff-bg:#212529;--ff-card-radius:1.5rem}.fitfight-booking-timetable{background:radial-gradient(circle at 14% 10%,#343a40 0,rgba(52,58,64,0) 45%),#212529;border-radius:1rem;box-shadow:0 22px 40px rgba(15,23,42,.28);color:var(--ff-text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;padding:1rem;width:100%}.ff-schedule-widget{display:flex;flex-direction:column;gap:.8rem}.ff-schedule-header{align-items:center;display:grid;gap:.5rem;grid-template-columns:repeat(12,1fr)}.ff-schedule-header>div:first-child{grid-column:1/span 6;min-width:0}.ff-schedule-label{color:var(--ff-muted);font-size:.75rem;grid-column:span 4;letter-spacing:.2em;margin:0;text-transform:uppercase}.ff-schedule-header h2{color:var(--ff-text);font-size:clamp(1.3rem,1.6vw,1.75rem);grid-column:span 4;margin:0;white-space:nowrap}.ff-schedule-controls{align-items:center;display:flex;flex-wrap:nowrap;gap:.4rem;grid-column:1/-1;overflow-x:auto;padding-bottom:.25rem}.ff-range-selector{align-items:center;background:#2b3035;border:1px solid rgba(248,249,250,.2);border-radius:999px;box-shadow:0 10px 24px rgba(15,23,42,.22);display:inline-flex;gap:.35rem;min-width:120px;padding:.3rem .65rem}.ff-range-action{align-items:center;background:none;border:none;border-radius:50%;color:var(--ff-text);cursor:pointer;display:flex;font-size:1rem;height:32px;justify-content:center;transition:background .2s ease;width:32px}.ff-range-action:hover{background:rgba(248,249,250,.15);color:#fff}.ff-range-text{font-size:.85rem;font-weight:600;min-width:130px;text-align:center}.ff-filter-group{align-items:center;display:flex;flex-wrap:nowrap;gap:.65rem}.ff-filter-select{align-self:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#2b3035;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%2716%27 height=%2716%27 fill=%27%23f8f9fa%27 class=%27bi bi-chevron-down%27%3E%3Cpath fill-rule=%27evenodd%27 d=%27M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708%27/%3E%3C/svg%3E");background-position:right .65rem center;background-repeat:no-repeat;background-size:16px 12px;border:1px solid rgba(248,249,250,.2);border-radius:999px;color:var(--ff-text);flex:0 0 auto;font-size:.85rem;height:36px;line-height:36px;min-width:120px;padding:0 2rem 0 .7rem;vertical-align:middle}.ff-filter-select option{background:#2b3035;color:#f8f9fa}.ff-week-grid{display:grid;gap:.35rem;grid-template-columns:repeat(7,minmax(110px,1fr));width:100%}.ff-week-column{background:#2b3035;border:1px solid rgba(248,249,250,.08);border-radius:1rem;box-shadow:0 10px 20px rgba(15,23,42,.25);display:flex;flex-direction:column;gap:.65rem;min-height:200px;padding:.5rem}.ff-day-header{color:var(--ff-text);font-size:.78rem;font-weight:700}.ff-day-slots{display:flex;flex:1;flex-direction:column;gap:.55rem}.ff-empty-slot{border:1px dashed rgba(248,249,250,.2);border-radius:.75rem;color:var(--ff-muted);font-size:.75rem;gap:.35rem;justify-content:center;min-height:90px;padding:.85rem;text-align:center}.ff-class-card,.ff-empty-slot{display:flex;flex-direction:column}.ff-class-card{background-position:50%;background-size:cover;border:none;border-radius:1rem;box-shadow:0 14px 26px rgba(15,23,42,.18);color:#fff;cursor:pointer;font-family:inherit;gap:.4rem;min-height:105px;padding:.5rem .55rem;position:relative;text-align:left;transition:transform .25s ease,box-shadow .25s ease;--ff-class-card-text-shadow:0 1px 2px rgba(15,23,42,.42)}.ff-class-card-duration,.ff-class-card-subtitle,.ff-class-card-time,.ff-class-card-time-range,.ff-class-card-title,.ff-class-card-trainer{color:inherit!important;text-shadow:var(--ff-class-card-text-shadow)}.ff-class-card:hover{box-shadow:0 30px 45px rgba(15,23,42,.35);transform:translateY(-6px)}.ff-class-card--canceled{filter:grayscale(.2);opacity:.65}.ff-class-card--past{box-shadow:0 20px 35px rgba(15,23,42,.18);cursor:not-allowed;filter:grayscale(.1);opacity:.55}.ff-class-card--past:hover{box-shadow:0 20px 35px rgba(15,23,42,.18);transform:none}.ff-class-card-time{align-items:flex-start;display:flex;flex-direction:column;font-size:.6rem;font-weight:700;gap:.08rem;width:100%}.ff-class-card-time-range{align-items:center;display:inline-flex;gap:.2rem;white-space:nowrap}.ff-class-card-time-mobile{display:none}.ff-class-card-duration{font-size:.55rem;opacity:.9}.ff-class-card-title{font-size:.62rem;font-weight:800;line-height:1.2;margin:0}.ff-class-card-subtitle{font-size:.52rem;margin:0;opacity:.85}.ff-class-card-footer{align-items:flex-start;display:flex;flex-direction:column;font-size:.5rem;gap:.2rem;letter-spacing:.04em;text-transform:uppercase}.ff-class-card-trainer{display:block;max-width:100%;opacity:.85;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ff-class-card-status{background:var(--ff-class-card-status-bg,hsla(0,0%,100%,.32));border-radius:999px;color:var(--ff-class-card-status-color,#fff);display:inline-block;font-size:.45rem;font-weight:700;letter-spacing:.05em;padding:.1rem .5rem}.ff-loading-state{background:#2b3035;border:1px solid rgba(248,249,250,.08);border-radius:var(--ff-card-radius);box-shadow:0 20px 45px rgba(15,23,42,.2);padding:2rem;text-align:center}.ff-detail-backdrop{align-items:center;backdrop-filter:blur(4px);background:rgba(15,23,42,.65);display:flex;inset:0;justify-content:center;overflow-y:auto;padding:max(1rem,env(safe-area-inset-top)) max(1rem,env(safe-area-inset-right)) max(1rem,env(safe-area-inset-bottom)) max(1rem,env(safe-area-inset-left));position:fixed;z-index:10000}.ff-detail-modal{animation:ff-slide-up .35s ease;background:#f8f9fa;border-radius:var(--ff-card-radius);box-shadow:0 35px 60px rgba(15,23,42,.35);display:flex;flex-direction:column;max-height:calc(100vh - 2rem);max-height:calc(100dvh - 2rem);overflow:hidden;position:relative;width:min(540px,100%)}.ff-detail-image{align-items:center;background:#000;display:flex;flex:0 0 auto;height:clamp(160px,28vh,220px);justify-content:center}.ff-detail-image img{height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.ff-detail-image-placeholder{align-items:center;color:hsla(0,0%,100%,.4);display:flex;font-size:2rem;height:100%;justify-content:center;width:100%}.ff-detail-content{display:flex;flex-direction:column;gap:.75rem;min-height:0;overflow-y:auto;padding:1.5rem}.ff-detail-label{color:#495057;margin:0}.ff-detail-meta{font-size:.9rem;margin:0}.ff-detail-location{display:flex;font-size:.9rem;gap:.25rem;line-height:1.4}.ff-detail-description{color:#495057;line-height:1.6;margin:0}.ff-detail-info-note{background:rgba(33,37,41,.12);border-radius:999px;color:#495057;font-size:.9rem;line-height:1.4;padding:.75rem 1rem;text-align:center}.ff-detail-close{align-items:center;background:#212529;border:none;border-radius:50%;box-shadow:0 10px 20px rgba(15,23,42,.15);color:#fff;cursor:pointer;display:flex;height:35px;justify-content:center;position:absolute;right:.75rem;top:.75rem;width:35px;z-index:2}.ff-detail-close i{font-size:1rem}.ff-modal-backdrop{z-index:10000}.ff-modal-backdrop .modal-content{background:#f8f9fa;color:#212529}.ff-modal-backdrop .bg-light{background:#e9ecef!important}.ff-modal-backdrop .btn-outline-secondary{border-color:rgba(33,37,41,.35);color:#212529}.ff-modal-backdrop .btn-outline-secondary:hover{background:#212529;border-color:#212529;color:#fff}.bg-primary-soft{background-color:var(--ff-primary-soft)!important}.bg-success-soft{background-color:var(--ff-success-soft)!important}.bg-danger-soft{background-color:var(--ff-danger-soft)!important}.rounded-4{border-radius:1.25rem!important}.ff-class-thumb-sm{flex:0 0 auto;height:44px;-o-object-fit:cover;object-fit:cover;width:44px}.ff-class-desc{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.progress{background-color:rgba(0,0,0,.05);height:6px}.progress-bar{transition:width .4s ease}.btn-primary{background-color:var(--ff-primary)!important;border-color:var(--ff-primary)!important}.btn-primary:hover{background-color:#343a40!important;border-color:#343a40!important}@keyframes ff-slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.fitfight-booking-timetable{border-radius:.9rem;padding:.75rem}.ff-schedule-widget{gap:.65rem}.ff-schedule-header{align-items:stretch;display:flex;flex-direction:column;gap:.6rem}.ff-schedule-header h2,.ff-schedule-label{grid-column:auto}.ff-schedule-controls{align-items:stretch;flex-direction:column;gap:.5rem;overflow:visible;padding-bottom:0}.ff-range-selector{justify-content:space-between;width:100%}.ff-range-text{font-size:.82rem;min-width:0}.ff-filter-group{display:grid;gap:.45rem;grid-template-columns:1fr;width:100%}.ff-filter-select{min-width:0;width:100%}.ff-filter-sport{display:none}.ff-week-grid{gap:.55rem;grid-template-columns:1fr}.ff-week-column{gap:.45rem;min-height:0;padding:.45rem .5rem}.ff-day-header{font-size:.74rem}.ff-day-slots{gap:.4rem}.ff-empty-slot{min-height:58px;padding:.5rem}.ff-class-card{gap:.25rem;min-height:72px;padding:.4rem .45rem}.ff-class-card-time{align-items:center;flex-direction:row;font-size:.68rem;gap:.25rem}.ff-class-card-time-desktop{display:none}.ff-class-card-time-mobile{display:inline-flex}.ff-class-card-duration{display:inline-flex;font-size:.54rem;opacity:.92}.ff-class-card-title{font-size:.72rem}.ff-class-card-subtitle{display:none}.ff-class-card-footer{align-items:center;display:flex;flex-direction:row;gap:.35rem;justify-content:space-between;margin-top:auto}.ff-class-card-trainer{display:inline-block;font-size:.52rem;max-width:65%;opacity:.9}.ff-class-card-status{font-size:.5rem}.ff-detail-backdrop{align-items:flex-start;padding:max(.65rem,env(safe-area-inset-top)) max(.65rem,env(safe-area-inset-right)) max(.65rem,env(safe-area-inset-bottom)) max(.65rem,env(safe-area-inset-left))}.ff-detail-modal{max-height:calc(100vh - 1.3rem);max-height:calc(100dvh - 1.3rem);width:min(100%,540px)}.ff-detail-image{height:clamp(130px,24vh,180px)}.ff-detail-content{gap:.6rem;padding:1rem}.ff-detail-close{height:32px;right:.5rem;top:.5rem;width:32px}}
