.profile-card{background:#fff;border-radius:15px;box-shadow:0 4px 20px rgba(0,0,0,.08);width:100%;max-width:1200px;margin:0 auto;overflow:hidden;position:relative}.profile-content{padding:2rem}.profile-image-container{width:100%;max-width:300px;margin:0 auto;display:flex;flex-direction:column;align-items:center}.profile-image{width:200px;height:200px;margin:0 auto;border:4px solid #e8f3f4}.profile-image:hover{transform:none;box-shadow:none}.profile-details{flex:1;min-width:0}.profile-details:hover{transform:none;box-shadow:none}.profile-details-title{font-size:1.7rem;color:#282828;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #b2d8db;position:relative}.profile-details-title:after{content:"";position:absolute;bottom:-2px;left:0;width:50px;height:2px;background-color:#95c2c5}.profile-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.profile-detail-item{background-color:#f8f9fa;padding:1rem;border-radius:8px;border-left:3px solid #b2d8db}.profile-detail-item:hover{transform:none;box-shadow:none}.profile-detail-item h4{font-size:1.1rem;color:#333;margin-bottom:.75rem;font-weight:600}.profile-detail-item p{font-size:1.25rem;font-weight:500;color:#333}.profile-actions{display:flex;gap:1rem;flex-wrap:wrap}.delete-warning{position:absolute;top:0;left:0;right:0;bottom:0;background:hsla(0,0%,100%,.95);z-index:10;padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.delete-warning-title{font-size:1.5rem;color:#d62828;margin-bottom:1rem}.delete-warning-text{max-width:500px;margin-bottom:2rem;line-height:1.6}.delete-warning-buttons{display:flex;gap:1rem}.form-feedback{padding:1rem;margin-bottom:1rem;border-radius:8px;font-weight:500}.form-feedback.error{background-color:rgba(220,53,69,.1);color:#dc3545;border:1px solid rgba(220,53,69,.2)}.form-feedback.success{background-color:rgba(40,167,69,.1);color:#28a745;border:1px solid rgba(40,167,69,.2)}.btn--edit{background-color:#b2d8db;color:#333;border:none;padding:.75rem 1.5rem;border-radius:50px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn--edit:hover{background-color:#92c6ca;transform:translateY(-2px);box-shadow:0 4px 10px rgba(146,198,202,.2)}.btn--logout{background-color:#f8f9fa;color:#333;border:1px solid #ddd;padding:.75rem 1.5rem;border-radius:50px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn--logout:hover{background-color:#e9ecef;transform:translateY(-2px);box-shadow:0 4px 10px rgba(233,236,239,.4)}.btn--delete{background-color:transparent;color:#dc3545;border:1px solid #dc3545;padding:.75rem 1.5rem;border-radius:50px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn--delete:hover{background-color:rgba(220,53,69,.1);transform:translateY(-2px)}.btn--danger{background-color:#dc3545;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:50px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn--danger:hover{background-color:#c82333;transform:translateY(-2px);box-shadow:0 4px 10px rgba(220,53,69,.3)}.btn--cancel{background-color:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:50px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn--cancel:hover{background-color:#5a6268;transform:translateY(-2px);box-shadow:0 4px 10px hsla(208,7%,46%,.3)}.login-input{width:100%;padding:.75rem 1rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:all .2s ease}.login-input:focus{border-color:#b2d8db;outline:none;box-shadow:0 0 0 3px rgba(178,216,219,.25)}@media (max-width:768px){.profile-details-grid{grid-template-columns:1fr}.profile-actions{justify-content:center}}.profile-tabs{display:flex;border-bottom:1px solid #e9ecef;margin-bottom:0;background-color:#f8f9fa}.profile-tab{padding:1.5rem 2rem;background:none;border:none;font-size:1.25rem;font-weight:500;color:#666;cursor:pointer;position:relative;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.profile-tab.active{color:#333;font-weight:700;background-color:#fff}.profile-tab.active:after{transform:scaleX(1)}.profile-tab.active:after,.profile-tab:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:4px;background-color:#b2d8db}.profile-tab:after{transform:scaleX(0);transition:transform .3s ease}.profile-tab:hover:after{transform:scaleX(.3)}.profile-tab:hover{color:#333}.booking-count{display:inline-flex;align-items:center;justify-content:center;background-color:#b2d8db;color:#333;font-size:.9rem;font-weight:700;width:1.8rem;height:1.8rem;border-radius:50%}.bookings-content{padding:2rem}.bookings-section{margin-bottom:3rem}.bookings-section-title{font-size:1.4rem;color:#333;margin-bottom:1.5rem;font-weight:600;border-bottom:1px solid #e9ecef;padding-bottom:.75rem}.bookings-list{display:flex;flex-direction:column;gap:1.25rem}.booking-card{background-color:#f8f9fa;border-radius:12px;padding:1.5rem;border-left:4px solid #b2d8db}.booking-card,.booking-card:hover{box-shadow:0 2px 10px rgba(0,0,0,.05)}.booking-card:hover{transform:none}.booking-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px dashed #e9ecef}.booking-date-time{display:flex;flex-direction:column}.booking-date{font-size:1.2rem;font-weight:600;color:#333;margin-bottom:.2rem}.booking-time{font-size:1rem;color:#666}.booking-status{display:flex;align-items:center}.status-badge{padding:.3rem .8rem;border-radius:20px;font-size:.75rem;font-weight:600;transition:all .2s ease}.status-confirmed{background-color:rgba(40,167,69,.1);color:#28a745;border:1px solid rgba(40,167,69,.2)}.status-cancelled{background-color:rgba(220,53,69,.1);color:#dc3545;border:1px solid rgba(220,53,69,.2)}.status-pending{background-color:rgba(255,193,7,.1);color:#ffc107;border:1px solid rgba(255,193,7,.2)}.booking-details{display:flex;justify-content:space-between;gap:1.5rem;margin-bottom:1.25rem}.booking-treatments{flex:1}.booking-service-title{font-size:.8rem;color:#666;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.booking-service-name{font-size:1.2rem;font-weight:500;color:#333}.booking-treatments-list{list-style:none;padding:0;margin:0}.booking-treatment-item{display:flex;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px dotted #e9ecef}.booking-treatment-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.treatment-name{font-size:1.1rem;font-weight:500;color:#333}.treatment-duration{font-size:.95rem;color:#666}.booking-price-duration{display:flex;flex-direction:column;align-items:flex-end;min-width:100px}.booking-price{font-size:1.2rem;font-weight:700;color:#28a745;margin-bottom:.5rem;transition:all .3s ease}.booking-duration{font-size:.85rem;color:#666}.booking-actions{display:flex;justify-content:flex-end;margin-top:.5rem;padding-top:.75rem;border-top:1px dashed #e9ecef}.btn-cancel-booking{background-color:transparent;color:#dc3545;border:1px solid #dc3545;padding:.5rem 1.2rem;border-radius:50px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-cancel-booking:hover{background-color:rgba(220,53,69,.1);transform:translateY(-2px)}.no-bookings{background-color:#f8f9fa;border-radius:12px;padding:2.5rem;text-align:center;color:#666;border-left:4px solid #e9ecef}.btn-book-new{display:inline-block;background-color:#b2d8db;color:#333;border:none;padding:.75rem 1.75rem;border-radius:50px;font-weight:600;margin-top:1.5rem;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn-book-new:hover{background-color:#92c6ca;transform:translateY(-2px);box-shadow:0 4px 10px rgba(146,198,202,.3)}.loyalty-points-container{background-color:#fff;border-radius:12px;padding:2rem;margin-bottom:2.5rem;box-shadow:0 4px 15px rgba(0,0,0,.05);border:1px solid #e9ecef;position:relative;overflow:hidden}.loyalty-points-container:before{content:"";position:absolute;top:0;left:0;width:100%;height:5px;background:linear-gradient(90deg,#b2d8db,#92c6ca)}.loyalty-points-title{font-size:1.4rem;color:#333;margin-bottom:2rem;font-weight:600;text-align:center}.loyalty-points-visualization{margin-bottom:2rem;padding:0 1rem}.loyalty-progress-container{position:relative;height:80px;margin:0 auto;max-width:700px}.loyalty-progress-bar{position:absolute;bottom:0;left:0;height:8px;background:linear-gradient(90deg,#b2d8db,#92c6ca);border-radius:4px;transition:width 1.5s cubic-bezier(.165,.84,.44,1)}.loyalty-progress-steps{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between}.loyalty-step{width:46px;height:46px;border-radius:50%;background-color:#fff;border:2px solid #ddd;display:flex;align-items:center;justify-content:center;font-weight:600;color:#666;transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:relative;z-index:2}.loyalty-step.active{background-color:#b2d8db;border-color:#92c6ca;color:#333;transform:scale(1.1);box-shadow:0 5px 15px rgba(146,198,202,.3)}.loyalty-points-status{text-align:center;margin-top:2.5rem}.loyalty-discount-available{padding:1.5rem;background-color:rgba(40,167,69,.08);border-radius:12px;border:1px solid rgba(40,167,69,.2)}.loyalty-congrats{display:inline-block;font-size:1.4rem;font-weight:700;color:#28a745;margin-bottom:.5rem}.btn-book-with-discount{display:inline-block;background-color:#28a745;color:#fff;border:none;padding:.75rem 1.75rem;border-radius:50px;font-weight:600;margin-top:1.5rem;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn-book-with-discount:hover{background-color:#218838;transform:translateY(-2px);box-shadow:0 4px 10px rgba(33,136,56,.3)}.loyalty-info{padding:1rem 0}.loyalty-remaining{font-size:1.2rem;margin-bottom:1rem;color:#333}.loyalty-count{font-weight:700;color:#b2d8db;font-size:1.4rem}.loyalty-explanation{font-size:.95rem;color:#666;max-width:600px;margin:0 auto;line-height:1.6}.price-details{opacity:.7;background-color:#f9f9f9;padding:.3rem .5rem;border-radius:.25rem;border-left:2px solid #b2d8db;margin-top:.3rem;font-size:.7rem}.booking-card:hover .price-details{opacity:1}.loyalty-progress-section{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:2px solid #f1f5f9}.loyalty-progress-card{background:linear-gradient(135deg,#f8f9fa,#fff);border-radius:1.2rem;padding:2rem;box-shadow:0 .4rem 1.2rem rgba(0,0,0,.08);border:1px solid #e9ecef;position:relative;overflow:hidden}.loyalty-progress-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#b2d8db,#9bc5c8)}.loyalty-header{gap:1.5rem;margin-bottom:2rem}.loyalty-header,.loyalty-icon{display:flex;align-items:center}.loyalty-icon{width:4rem;height:4rem;border-radius:50%;background:linear-gradient(135deg,#b2d8db,#9bc5c8);justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 .4rem 1.2rem rgba(178,216,219,.3)}.loyalty-title h3{font-size:1.8rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.loyalty-title p{font-size:1.3rem;color:#6b7280;margin:0}.loyalty-loading{text-align:center;padding:2rem}.spinner{width:3rem;height:3rem;border:3px solid #e5e7eb;border-top-color:#b2d8db;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loyalty-eligible{text-align:center;padding:2rem;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:1rem;border:2px solid #bbf7d0}.celebration-badge{font-size:4rem;margin-bottom:1rem;display:block}.loyalty-eligible h4{font-size:2rem;font-weight:700;color:#059669;margin:0 0 1rem}.loyalty-eligible p{font-size:1.5rem;color:#166534;margin:0}.loyalty-progress{background:rgba(178,216,219,.1);border-radius:1rem;padding:2rem}.loyalty-reset{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:1rem;padding:2rem;border:2px solid #0ea5e9}.reset-info{display:flex;align-items:flex-start;gap:1.5rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid rgba(14,165,233,.2)}.reset-icon{font-size:3rem;flex-shrink:0;background:linear-gradient(135deg,#22c55e,#16a34a);width:4rem;height:4rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 .4rem 1.2rem rgba(34,197,94,.3)}.reset-content h4{font-size:1.8rem;font-weight:700;color:#0c4a6e;margin:0 0 1rem}.reset-description{font-size:1.4rem;color:#075985;margin:0 0 1rem;line-height:1.5}.reset-restart{font-size:1.3rem;color:#0369a1;font-weight:600;margin:0;padding:.8rem 1.2rem;background:rgba(14,165,233,.1);border-radius:.8rem;border-left:4px solid #0ea5e9}.progress-section{background:hsla(0,0%,100%,.7);border-radius:1rem;padding:2rem;border:1px solid rgba(14,165,233,.2)}.progress-info{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem}.progress-numbers{font-size:2.4rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.progress-text{font-size:1.3rem;color:#6b7280}.progress-bar-container{margin:2rem 0}.progress-bar{width:100%;height:1.2rem;background:#e5e7eb;overflow:hidden}.progress-bar,.progress-fill{border-radius:.6rem;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#b2d8db,#9bc5c8);transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.3) 50%,transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.progress-remaining{text-align:center}.remaining-count{font-size:1.8rem;font-weight:700;color:#b2d8db;display:block;margin-bottom:.5rem}.remaining-text{font-size:1.4rem;color:#6b7280}.birthday-bonus{margin-top:2rem;background:linear-gradient(135deg,#fdf2f8,#fce7f3);border:2px solid #f9a8d4;border-radius:1rem;padding:1.5rem;display:flex;align-items:center;gap:1.5rem}.birthday-icon{font-size:3rem;flex-shrink:0}.birthday-text h4{font-size:1.6rem;font-weight:700;color:#be185d;margin:0 0 .5rem}.birthday-text p{font-size:1.3rem;color:#9d174d;margin:0}.loyalty-error{text-align:center;padding:2rem;background:#fef2f2;border:1px solid #fecaca;border-radius:1rem;color:#dc2626}@media (max-width:768px){.loyalty-progress-card{padding:1.5rem}.loyalty-header{flex-direction:column;text-align:center;gap:1rem}.loyalty-icon{width:3.5rem;height:3.5rem}.loyalty-title h3{font-size:1.6rem}.progress-numbers{font-size:2rem}.remaining-count{font-size:1.6rem}.birthday-bonus{flex-direction:column;text-align:center}.celebration-badge{font-size:3rem}.loyalty-eligible h4{font-size:1.8rem}.loyalty-reset{padding:1.5rem}.reset-info{flex-direction:column;text-align:center;gap:1rem}.reset-icon{width:3.5rem;height:3.5rem;font-size:2.5rem}.reset-content h4{font-size:1.6rem}.reset-description{font-size:1.3rem}.reset-restart{font-size:1.2rem;padding:.6rem 1rem}.progress-section{padding:1.5rem}}@media (max-width:480px){.loyalty-progress-card{padding:1rem}.loyalty-title h3{font-size:1.4rem}.progress-numbers{font-size:1.8rem}.loyalty-eligible h4{font-size:1.6rem}.birthday-text h4{font-size:1.4rem}.loyalty-reset{padding:1rem}.reset-icon{width:3rem;height:3rem;font-size:2rem}.reset-content h4{font-size:1.4rem}.reset-description{font-size:1.2rem}.reset-restart{font-size:1.1rem;padding:.5rem .8rem}.progress-section{padding:1rem}}