.reservationContainer .tab-navigation{display:flex;background:#ffffff1a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:15px;padding:8px;margin-bottom:24px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #1f26875e}.reservationContainer .tab-btn{flex:1;padding:12px 20px;border:none;background:transparent;border-radius:10px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:600;color:var(--text-secondary);position:relative;overflow:hidden}.reservationContainer .tab-btn.active{background:rgba(var(--primary-main-rgb),.2);color:var(--primary-main);box-shadow:0 4px 16px rgba(var(--primary-main-rgb),.3)}.reservationContainer .tab-btn:hover{background:#ffffff1a;transform:translateY(-2px)}.reservationContainer .reservation-plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;margin-top:24px}.reservationContainer .reservation-plan-card{background:#ffffff1a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:0;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;cursor:pointer;box-shadow:0 8px 32px #1f268733}.reservationContainer .reservation-plan-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s ease;z-index:1}.reservationContainer .reservation-plan-card:hover:before{left:100%}.reservationContainer .reservation-plan-card:hover{transform:translateY(-8px) scale(1.02);border-color:rgba(var(--primary-main-rgb),.4);box-shadow:0 25px 50px #1f268766}.reservationContainer .plan-thumbnail{width:100%;height:200px;overflow:hidden;border-radius:20px 20px 0 0;position:relative}.reservationContainer .plan-thumbnail img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;transition:transform .4s ease}.reservationContainer .reservation-plan-card:hover .plan-thumbnail img{transform:scale(1.05)}.reservationContainer .plan-thumbnail-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#0000004d,#0000001a);opacity:0;transition:opacity .3s ease}.reservationContainer .reservation-plan-card:hover .plan-thumbnail-overlay{opacity:1}.reservationContainer .plan-content{padding:24px;position:relative;z-index:2}.reservationContainer .plan-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.reservationContainer .plan-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3}.reservationContainer .plan-popular{background:linear-gradient(135deg,var(--secondary-main),var(--secondary-light));color:#fff;padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:600;box-shadow:0 4px 12px rgba(var(--secondary-main-rgb),.3);white-space:nowrap}.reservationContainer .plan-description{color:var(--text-secondary);margin-bottom:20px;line-height:1.6;font-size:.95rem}.reservationContainer .plan-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px;background:#ffffff1a;border-radius:12px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.reservationContainer .plan-price{font-size:1.5rem;font-weight:700;color:var(--primary-main);margin:0}.reservationContainer .plan-sessions{background:rgba(var(--primary-main-rgb),.1);color:var(--primary-main);padding:8px 16px;border-radius:10px;font-size:.9rem;font-weight:600;border:1px solid rgba(var(--primary-main-rgb),.2)}.reservation-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;visibility:visible;transition:all .4s cubic-bezier(.4,0,.2,1)}.reservation-modal-content{background:#fffffff2;backdrop-filter:blur(25px);-webkit-backdrop-filter:blur(25px);border:1px solid rgba(255,255,255,.3);border-radius:24px;max-width:900px;width:100%;max-height:90vh;overflow:hidden;transform:scale(.9) translateY(20px);transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 25px 50px -12px #00000040;position:relative}.reservation-modal-content:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffffff1a,#ffffff0d,#ffffff1a);border-radius:24px;pointer-events:none}.reservation-modal-header{padding:24px 24px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.2);margin-bottom:0;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);position:relative;z-index:1}.reservation-modal-title{font-size:1.6rem;font-weight:700;color:var(--text-primary);margin:0;background:linear-gradient(135deg,var(--primary-main),var(--primary-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.reservation-modal-close{background:#fff3;border:1px solid rgba(255,255,255,.3);font-size:1.2rem;cursor:pointer;color:var(--text-secondary);transition:all .3s ease;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);pointer-events:auto;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:10}.reservation-modal-close:hover{color:var(--text-primary);background:#ffffff4d;transform:rotate(90deg) scale(1.1)}.reservation-modal-close:active{transform:rotate(90deg) scale(.95)}.reservation-modal-body{padding:24px;max-height:calc(90vh - 120px);overflow-y:auto;position:relative;z-index:1}.reservationContainer .plan-info{background:#ffffff1a;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:20px;margin-bottom:24px}.reservationContainer .plan-info .plan-price{font-size:1.8rem;font-weight:800;background:linear-gradient(135deg,var(--primary-main),var(--primary-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.reservationContainer .timeslots-calendar{display:grid;gap:20px}.reservationContainer .date-section{background:#ffffff1a;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border-radius:16px;padding:20px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #1f26871a}.reservationContainer .date-header{font-weight:700;color:var(--text-primary);margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--primary-main);font-size:1.1rem;background:linear-gradient(135deg,var(--primary-main),var(--primary-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.reservationContainer .timeslots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.reservationContainer .timeslot-item{background:#fff3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);border-radius:12px;padding:16px 12px;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.reservationContainer .timeslot-item:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(var(--primary-main-rgb),.1),rgba(var(--primary-light-rgb),.1));opacity:0;transition:opacity .3s ease}.reservationContainer .timeslot-item:hover:before{opacity:1}.reservationContainer .timeslot-item:hover{transform:translateY(-4px);border-color:var(--primary-main);box-shadow:0 8px 24px rgba(var(--primary-main-rgb),.3)}.reservationContainer .timeslot-item.selected{background:rgba(var(--primary-main-rgb),.2);border-color:var(--primary-main);color:var(--primary-main);font-weight:600;box-shadow:0 8px 24px rgba(var(--primary-main-rgb),.4);transform:translateY(-2px)}.reservationContainer .timeslot-item.disabled{opacity:.5;cursor:not-allowed;background:#ffffff1a}.reservationContainer .timeslot-time{font-weight:600;margin-bottom:6px;font-size:.95rem;position:relative;z-index:1}.reservationContainer .timeslot-capacity{font-size:.8rem;color:var(--text-secondary);position:relative;z-index:1}.reservationContainer .modal-footer{background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;padding:20px;border:1px solid rgba(255,255,255,.2)}.reservationContainer .empty-reservation-icon{font-size:4rem;margin-bottom:20px;opacity:.5;background:linear-gradient(135deg,var(--primary-main),var(--primary-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media (max-width: 768px){.reservationContainer .reservation-plans-grid{grid-template-columns:1fr;gap:16px}.reservationContainer .timeslots-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.reservation-modal-content{max-height:95vh;border-radius:20px}.reservationContainer .plan-header{flex-direction:column;gap:12px;align-items:flex-start}.reservationContainer .plan-details{flex-direction:column;gap:12px;text-align:center}}.reservationContainer .loading-shimmer{background:linear-gradient(90deg,#ffffff1a 25%,#fff3,#ffffff1a 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.reservationContainer .empty-reservation-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.reservationContainer .empty-reservation-icon{font-size:4rem;margin-bottom:20px;opacity:.5}
