.header{background:linear-gradient(135deg,#056cf2,#0597f2);color:#fff;padding:20px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-shadow:0 4px 20px #0000001a;position:relative;overflow:hidden;border-radius:0 0 30px 30px}.header-left{display:flex;align-items:center;z-index:1}.header-logo{height:60px;width:120px;display:block;object-fit:contain;filter:brightness(0) invert(1)}.header-center{flex:1;text-align:right;z-index:1}.page-title{margin:0;font-size:1.2rem;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.1)}.user-info{margin-top:5px;opacity:.9;font-size:.8rem}.user-info p{margin:0;color:#fff;line-height:.9}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px;z-index:1}.staff-info{display:flex;align-items:center;gap:15px}.staff-photo{position:relative}.staff-image{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.3);box-shadow:0 4px 15px #0003;transition:all .3s ease}.staff-image:hover{transform:scale(1.05);border-color:#ffffff80}.staff-photo-placeholder{width:60px;height:60px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:1.5rem;border:3px solid rgba(255,255,255,.3);box-shadow:0 4px 15px #0003}.staff-details{display:flex;flex-direction:column;gap:2px;text-align:right}.staff-name{margin:0;font-size:1.1rem;font-weight:600;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.1)}.staff-department{margin:0;font-size:.85rem;color:#fffc;font-weight:400}.page-info{text-align:right}.page-label{background:#fff3;color:#fff;padding:8px 16px;border-radius:20px;font-size:.85rem;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.edit-form{padding:10px}.form-group{margin-bottom:20px;text-align:left}.form-group label{display:block;font-weight:600;margin-bottom:8px;color:#34495e}.form-group input[type=datetime-local],.form-group input[type=text],.form-group textarea{width:100%;padding:12px 15px;border:1px solid #dcdfe6;border-radius:8px;font-size:1rem;font-family:Sarabun,sans-serif;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#056cf2;box-shadow:0 0 0 2px #056cf233}.form-actions{display:flex;gap:15px;margin-top:25px}.form-actions button{flex:1;padding:12px;border-radius:10px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background-color:#27ae60;color:#fff}.btn-primary:hover{background-color:#229954}.btn-secondary{background-color:#ecf0f1;color:#7f8c8d;border:1px solid #bdc3c7}.btn-secondary:hover{background-color:#e0e6e8}:root{--primary-color: #007AFF;--secondary-color: #5AC8FA;--bg-color: #F8FAFC;--card-bg: #FFFFFF;--text-color: #1E293B;--text-light: #64748B;--status-pending: #F59E0B;--status-done: #10B981;--gradient-primary: linear-gradient(135deg, #667eea 0%, #007AFF 100%);--gradient-secondary: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--shadow-soft: 0 10px 25px rgba(0, 0, 0, .1);--shadow-hover: 0 20px 40px rgba(0, 0, 0, .15)}body{margin:0;font-family:Kanit,-apple-system,BlinkMacSystemFont,sans-serif;background:linear-gradient(135deg,#667eea,#007aff);color:var(--text-color);min-height:100vh}.user-info{margin-top:8px;font-size:.9rem;color:var(--text-light);opacity:.8}.container{padding:20px;max-width:600px;margin:0 auto;min-height:calc(100vh - 120px)}#appointment-list{display:flex;flex-direction:column;gap:20px;padding-bottom:20px}.appointment-card2{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:var(--shadow-soft);overflow:hidden;transition:all .3s ease;border:1px solid rgba(255,255,255,.2);display:flex;align-items:stretch}.appointment-card2:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover)}.time-strip{background:var(--gradient-primary);color:#fff;padding:20px 15px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:80px;position:relative;overflow:hidden;flex-shrink:0}.time-strip:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,rgba(255,255,255,.1) 0%,transparent 50%,rgba(255,255,255,.1) 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.time-strip .hour-minute{font-size:2rem;font-weight:700;line-height:1;margin-top:5px;text-shadow:0 2px 4px rgba(0,0,0,.3);position:relative;z-index:1}.member-photo-container{position:relative;width:70px;height:70px;margin-bottom:10px;border-radius:50%;overflow:hidden;box-shadow:0 8px 25px #0003;border:4px solid rgba(255,255,255,.3);transition:all .3s ease}.member-photo-container:hover{transform:scale(1.05);box-shadow:0 12px 35px #0000004d}.member-photo{width:100%;height:100%;object-fit:cover;transition:all .3s ease}.member-photo-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.card-content{padding:25px;display:flex;flex-direction:column;gap:15px;flex:1;justify-content:space-between}.card-content h2{margin:0 0 5px;font-size:1.3rem;font-weight:600;color:var(--text-color);line-height:1.3}.card-content p{margin:0 0 1px;font-size:1rem;color:var(--text-light);display:flex;align-items:center;gap:8px}.card-content p:before{content:"📍";font-size:1.1rem}.status-badge{display:inline-flex;align-items:center;padding:8px 16px;border-radius:25px;font-size:.85rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 12px #00000026;transition:all .3s ease;align-self:flex-start;margin-top:auto}.status-badge:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0003}.status-pending{background:linear-gradient(135deg,#f59e0b,#f97316)}.status-done{background:linear-gradient(135deg,#10b981,#059669)}.info-state{text-align:center;margin-top:60px;color:var(--text-light);background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:40px 20px;border-radius:20px;box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,.2);animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.info-state p{font-size:1.1rem;margin:0;color:var(--text-color);font-weight:500}.info-state:has(p:contains("กำลังโหลด")){position:relative}.info-state:has(p:contains("กำลังโหลด")):before{content:"";position:absolute;top:50%;left:50%;width:40px;height:40px;margin:-20px 0 0 -20px;border:3px solid rgba(102,126,234,.3);border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 480px){.container{padding:15px}.appointment-card2{margin-bottom:2px}.time-strip{min-width:70px;padding:15px 10px}.time-strip .hour-minute{font-size:1.6rem}.member-photo-container{width:60px;height:60px}.card-content{padding:20px}.card-content h2{font-size:1.2rem}.info-state{margin-top:40px;padding:30px 15px}}.members-container{max-width:1200px;margin:0 auto;padding:20px}.member-card{display:flex;flex-direction:row;justify-content:space-between;background:#fff;border-radius:15px;padding:10px;margin-bottom:10px;box-shadow:0 5px 20px #00000014;transition:all .3s ease;border:1px solid #e1e8ed;position:relative;overflow:hidden;cursor:pointer}.member-photo-section{display:flex;align-items:center;justify-content:center}.member-photo{width:150px;height:150px;border-radius:50%;object-fit:cover;border:4px solid #f1f5f9;box-shadow:0 4px 15px #0000001a;transition:all .3s ease}.member-photo-placeholder{width:150px;height:150px;border-radius:50%;background:linear-gradient(135deg,#056cf2,#0549a2);display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff;border:4px solid #f1f5f9;box-shadow:0 4px 15px #0000001a;transition:all .3s ease}.member-info-section{display:flex;flex-direction:column;justify-content:space-between;padding-left:20px}.member-info{flex:1}.member-name{margin:0 0 8px;color:#1e293b;font-size:1.3rem;font-weight:600;line-height:1.3}.member-age,.member-id,.member-phone{margin:0 0 5px;color:#64748b;font-size:.9rem;display:flex;align-items:center;gap:5px}.member-actions{display:flex;gap:10px;margin-top:15px}.call-button,.view-button{padding:8px 16px;border:none;border-radius:20px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:5px}.call-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b9814d}.call-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #10b98166}.view-button{background:linear-gradient(135deg,#056cf2,#0549a2);color:#fff;box-shadow:0 2px 8px #056cf24d}.view-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #056cf266}.profile-content{max-width:800px;margin:0 auto;padding:20px}.profile-section,.statistics-section{margin-bottom:30px}.profile-section h2,.statistics-section h2{color:#2c3e50;font-size:1.5rem;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #3498db;display:flex;align-items:center;gap:10px}.profile-card{background:linear-gradient(135deg,#056cf2,#0549a2);border-radius:15px;padding:25px;color:#fff;box-shadow:0 10px 30px #0000001a;transition:transform .3s ease}.profile-card:hover{transform:translateY(-5px)}.profile-header{display:flex;align-items:center;gap:20px}.profile-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.3)}.profile-photo-placeholder{width:80px;height:80px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:2rem;border:3px solid rgba(255,255,255,.3)}.profile-info h3{margin:0 0 5px;font-size:1.5rem;font-weight:600}.profile-info .organization{margin:0;opacity:.9;font-size:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;margin-top:20px}.stat-card{background:#fff;border-radius:12px;padding:20px;text-align:center;box-shadow:0 5px 15px #00000014;transition:all .3s ease;border:1px solid #e1e8ed}.stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 25px #00000026}.stat-number{font-size:2.5rem;font-weight:700;color:#3498db;margin-bottom:8px;line-height:1}.stat-label{color:#7f8c8d;font-size:.9rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.profile-content{padding:15px}.profile-header{flex-direction:column;text-align:center;gap:15px}.profile-photo,.profile-photo-placeholder{width:70px;height:70px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:15px}.stat-number{font-size:2rem}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.profile-section h2,.statistics-section h2{font-size:1.3rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.profile-card,.stat-card{animation:fadeInUp .6s ease-out}.stat-card:nth-child(1){animation-delay:.1s}.stat-card:nth-child(2){animation-delay:.2s}.stat-card:nth-child(3){animation-delay:.3s}.stat-card:nth-child(4){animation-delay:.4s}.info-state{text-align:center;padding:40px 20px;color:#7f8c8d}.header{background:linear-gradient(135deg,#056cf2,#0549a2);color:#fff;padding:20px;text-align:center;margin-bottom:20px}.header h1{margin:0;font-size:1.8rem;font-weight:600}.user-info{margin-top:10px;opacity:.9;font-size:.9rem}.appointments-container,.appointments-list{max-width:1000px;margin:0 auto;padding:20px}.search-container{margin-bottom:20px}.search-box{position:relative;display:flex;align-items:center;background:#fff;border-radius:15px;box-shadow:0 5px 15px #00000014;border:1px solid #e1e8ed;overflow:hidden;transition:all .3s ease}.search-box:focus-within{box-shadow:0 8px 25px #056cf226;border-color:#056cf2}.search-icon{padding:15px 20px;color:#7f8c8d;font-size:1.1rem;background:#f8f9fa;border-right:1px solid #e1e8ed}.search-input{flex:1;padding:15px 20px;border:none;outline:none;font-size:1rem;background:transparent;color:#2c3e50}.search-input::placeholder{color:#bdc3c7;font-style:italic}.clear-search{background:#e74c3c;color:#fff;border:none;padding:8px 12px;border-radius:50%;cursor:pointer;font-size:.8rem;margin-right:15px;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:30px;height:30px}.clear-search:hover{background:#c0392b;transform:scale(1.1)}.search-results-info{margin-top:10px;padding:8px 15px;background:linear-gradient(135deg,#056cf2,#0549a2);color:#fff;border-radius:10px;font-size:.9rem;text-align:center;box-shadow:0 2px 10px #056cf233}.tab-content{min-height:400px}.empty-state{text-align:center;padding:60px 20px;color:#7f8c8d}.empty-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.empty-state h3{margin:0 0 10px;color:#2c3e50;font-size:1.3rem}.empty-state p{margin:0;font-size:1rem;line-height:1.5}.appointment-card{display:grid;grid-template-columns:1fr 2fr;background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 5px 20px #00000014;transition:all .3s ease;border:1px solid #e1e8ed;margin-bottom:20px}.appointment-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px #00000026}.appointment-left{background:linear-gradient(135deg,#056cf2,#0549a2);color:#fff;padding:20px;display:flex;flex-direction:column;justify-content:space-between;min-width:120px;flex:1}.appointment-date{text-align:center}.appointment-date .date{font-size:.9rem;font-weight:500;margin-bottom:5px;opacity:.9}.appointment-date .time{font-size:1.8rem;font-weight:700;margin-bottom:15px}.status-button{background:#f39c12;color:#fff;border:none;padding:8px 16px;border-radius:20px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.status-button.status-done{background:#2ecc71}.status-button.status-pending{background:#f39c12}.status-button.status-overdue{background:#e74c3c}.appointment-right{padding:0;display:grid;grid-template-columns:3fr 1fr;justify-content:space-between;align-items:start;flex-wrap:nowrap;position:relative;gap:10px}.member-info h3{margin:0 0 8px;color:#2c3e50;font-size:.9rem;font-weight:600;line-height:1.3;text-align:start}.member-age,.member-phone,.member-location{margin:0 0 5px;color:#7f8c8d;font-size:.9rem;display:flex;align-items:center;gap:5px}.member-photo{width:50px;height:50px;border-radius:50%;object-fit:cover;border:3px solid white;box-shadow:0 2px 8px #0000001a}.member-photo-placeholder{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#056cf2,#0549a2);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;border:3px solid white;box-shadow:0 2px 8px #0000001a}.modal-member-photo-container{margin:0 auto 15px;width:90px;height:90px}.modal-member-photo{width:100%;height:100%;border-radius:50%;object-fit:cover;border:4px solid #056CF2;box-shadow:0 4px 10px #0000001a}.modal-member-photo-placeholder{width:100%;height:100%;border-radius:50%;background:#e1e8ed;color:#7f8c8d;display:flex;align-items:center;justify-content:center;font-size:3rem;border:4px solid #bdc3c7}.fixed-top-section{position:sticky;top:0;z-index:100;background:#f8fafc;padding:20px;border-bottom:1px solid #e2e8f0;box-shadow:0 2px 10px #0000000d}.scrollable-content{flex:1;overflow-y:auto;padding:0}.container{max-width:1200px;margin:0 auto}.appointments-container{max-width:1000px;margin:0 auto}@media (max-width: 768px){.appointments-container,.appointments-list{padding:2px}.search-box{margin:0 10px}.search-input{font-size:.9rem;padding:12px 15px}.search-icon{padding:12px 15px;font-size:1rem}.search-results-info{margin:10px;font-size:.8rem}.appointment-card{flex-direction:column}.appointment-left{min-width:auto;padding:15px}.appointment-right{padding:15px;flex-direction:column;text-align:center}.member-photo-container{margin-left:0}.appointment-date .time{font-size:1.5rem}.tab-navigation{flex-direction:column;gap:5px}.tab-button{padding:10px 15px;font-size:.9rem}.fixed-top-section,.scrollable-content{padding:15px}}@media (max-width: 480px){.header h1{font-size:1.5rem}.search-input{font-size:.85rem;padding:10px 12px}.search-icon{padding:10px 12px;font-size:.9rem}.appointment-left,.appointment-right{padding:12px}.member-info h3{font-size:1.1rem}.member-photo,.member-photo-placeholder{width:50px;height:50px}.tab-button{font-size:.8rem;padding:8px 12px}.fixed-top-section,.scrollable-content{padding:10px}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.appointment-card{animation:slideInLeft .6s ease-out}.appointment-card:hover .member-details h3{color:#667eea}.appointment-date .date{position:relative}.appointment-date .date:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:2px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transition:transform .3s ease}.appointment-card:hover .appointment-date .date:after{transform:scaleX(1)}.appointment-card.clickable{cursor:pointer}.appointment-actions{text-align:center}.appointment-actions h3{font-size:1.5rem;margin-bottom:5px}.appointment-actions p{color:#7f8c8d;margin-bottom:25px}.action-buttons{display:flex;flex-direction:column;gap:15px}.action-btn{width:100%;padding:15px;border-radius:12px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;color:#fff}.action-btn:hover{opacity:.9;transform:translateY(-2px)}.action-btn.edit{background-color:#f39c12}.action-btn.notify{background-color:#2980b9}.action-btn.cancel{background-color:#c0392b}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:15px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column}.modal-header{padding:15px 20px;border-bottom:1px solid #e1e8ed;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0}.modal-close-button{background:none;border:none;font-size:2rem;cursor:pointer;color:#7f8c8d}.modal-body{padding:20px;overflow-y:auto}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e1e8ed;box-shadow:0 -2px 10px #0000001a;z-index:1000;padding:10px 0}.nav-container{display:flex;justify-content:space-around;align-items:center;max-width:500px;margin:0 auto;position:relative}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;border:none;background:transparent;cursor:pointer;transition:all .3s ease;border-radius:12px;min-width:60px}.nav-item:hover{background:#667eea1a}.nav-item.active{background:linear-gradient(135deg,#056cf2,#0549a2);color:#fff;transform:translateY(-2px);box-shadow:0 4px 15px #667eea4d}.nav-icon{font-size:1.5rem;line-height:1}.nav-label{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;line-height:1}.fab-create{position:absolute;top:-25px;left:50%;transform:translate(-50%);width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#056cf2,#0549a2);border:none;color:#fff;cursor:pointer;box-shadow:0 4px 20px #667eea66;transition:all .3s ease;z-index:1001;border:3px solid #fefefe}.fab-create:hover{transform:translate(-50%) scale(1.1);box-shadow:0 6px 25px #667eea99}.fab-icon{font-size:1.5rem;line-height:1}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.modal-content{background:#fff;border-radius:20px;padding:0;max-width:400px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #e1e8ed;background:linear-gradient(135deg,#056cf2,#0549a2);color:#fff;border-radius:20px 20px 0 0}.modal-header h2{margin:0;font-size:1.3rem;font-weight:600}.modal-close{background:#fff3;border:none;color:#fff;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:1rem;transition:background .3s ease}.modal-close:hover{background:#ffffff4d}.appointment-form{padding:25px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#2c3e50;font-size:.9rem}.form-group select,.form-group input{width:100%;padding:12px 16px;border:2px solid #e1e8ed;border-radius:12px;font-size:1rem;transition:border-color .3s ease;background:#fff}.form-group select:focus,.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input::placeholder{color:#bdc3c7}.form-actions{display:flex;gap:12px;margin-top:30px}.btn-cancel,.btn-submit{flex:1;padding:12px 20px;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel{background:#ecf0f1;color:#7f8c8d}.btn-cancel:hover{background:#d5dbdb}.btn-submit{background:linear-gradient(135deg,#056cf2,#0549a2);color:#fff}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-submit:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 480px){.nav-container{max-width:100%;padding:0 10px}.nav-item{min-width:50px;padding:6px 8px}.nav-icon{font-size:1.3rem}.nav-label{font-size:.6rem}.fab-create{width:60px;height:60px;top:-35px}.fab-icon{font-size:1.3rem}.modal-content{margin:10px;max-width:calc(100% - 20px)}.modal-header{padding:15px 20px}.modal-header h2{font-size:1.2rem}.appointment-form{padding:20px}.form-actions{flex-direction:column}}.nav-item.active .nav-icon{animation:bounce .6s ease}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-5px)}60%{transform:translateY(-3px)}}.btn-submit:disabled{position:relative}.btn-submit:disabled:after{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin:-8px 0 0 -8px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-select,.error-select{width:100%;padding:12px 16px;border:2px solid #e1e8ed;border-radius:12px;font-size:1rem;background:#fff;color:#7f8c8d;text-align:center}.loading-select{background:#f8f9fa;border-color:#056cf2;color:#056cf2}.error-select{background:#fff5f5;border-color:#e74c3c;color:#e74c3c}.member-selector{position:relative}.selected-member{display:flex;align-items:center;justify-content:space-between;background:#f8f9fa;border:2px solid #e1e8ed;border-radius:12px;padding:15px;margin-bottom:10px}.selected-member-info{display:flex;align-items:center;gap:15px;flex:1}.selected-member-photo{position:relative;width:60px;height:60px}.selected-member-photo img{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid #056CF2}.selected-member-photo-placeholder{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#056cf2,#0549a2);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;border:3px solid #056CF2}.selected-member-details h4{margin:0 0 5px;color:#1e293b;font-size:1.1rem;font-weight:600}.selected-member-details p{margin:0 0 2px;color:#64748b;font-size:.9rem}.change-member-btn,.clear-member-btn{padding:8px 12px;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease}.change-member-btn{background:#056cf2;color:#fff;margin-right:8px}.change-member-btn:hover{background:#0549a2}.clear-member-btn{background:#e74c3c;color:#fff;width:35px;height:35px;border-radius:50%;display:flex;align-items:center;justify-content:center}.clear-member-btn:hover{background:#c0392b}.select-member-btn{width:100%;padding:15px;background:#f8f9fa;border:2px dashed #bdc3c7;border-radius:12px;color:#64748b;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.select-member-btn:hover{background:#e9ecef;border-color:#056cf2;color:#056cf2}.member-selector-modal{position:fixed;inset:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.member-selector-content{background:#fff;border-radius:20px;width:100%;max-width:500px;max-height:80vh;overflow:hidden;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column}.member-selector-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e1e8ed;background:linear-gradient(135deg,#056cf2,#0549a2);color:#fff}.member-selector-header h3{margin:0;font-size:1.3rem;font-weight:600}.close-selector-btn{background:#fff3;border:none;color:#fff;width:35px;height:35px;border-radius:50%;cursor:pointer;font-size:1.2rem;transition:all .3s ease}.close-selector-btn:hover{background:#ffffff4d}.member-search-container{padding:15px 20px;border-bottom:1px solid #e1e8ed;background:#f8f9fa}.member-search-box{position:relative;display:flex;align-items:center;background:#fff;border-radius:12px;border:1px solid #e1e8ed;overflow:hidden;box-shadow:0 2px 8px #0000001a}.member-search-input{flex:1;padding:12px 15px;border:none;outline:none;font-size:1rem;background:transparent}.member-search-input::placeholder{color:#bdc3c7}.clear-search-btn{background:#e74c3c;color:#fff;border:none;padding:8px;border-radius:50%;cursor:pointer;margin-right:10px;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.member-list{flex:1;max-height:400px;overflow-y:auto;padding:10px 0;background:#fff}.member-option{display:flex;align-items:center;gap:15px;padding:15px 20px;cursor:pointer;transition:all .3s ease;border-bottom:1px solid #f1f5f9}.member-option:hover{background:#f8f9fa}.member-option:last-child{border-bottom:none}.member-option-photo{position:relative;width:50px;height:50px}.member-option-photo img{width:50px;height:50px;border-radius:50%;object-fit:cover;border:2px solid #e1e8ed}.member-option-photo-placeholder{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#056cf2,#0549a2);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#fff;border:2px solid #e1e8ed}.member-option-info h4{margin:0 0 5px;color:#1e293b;font-size:1rem;font-weight:600}.member-option-info p{margin:0 0 2px;color:#64748b;font-size:.85rem}.no-members-found{padding:30px 20px;text-align:center;color:#64748b}.no-members-found p{margin:0;font-size:1rem}.app-container{min-height:100vh;display:flex;flex-direction:column;background:#f8f9fa}.app-content{flex:1;padding-bottom:80px}*{box-sizing:border-box}@font-face{font-family:Prompt;src:url(/fonts/Prompt-Regular.ttf) format("ttf");font-weight:400;font-style:normal;font-display:swap}body{margin:0;font-family:Prompt,sans-serif;background:#f8f9fa}.container{max-width:1200px;margin:0 auto;padding:0 20px}.info-state{text-align:center;padding:60px 20px;color:#7f8c8d}.info-state p{font-size:1.1rem;margin:0}html{scroll-behavior:smooth}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #0549A2;outline-offset:2px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media print{.bottom-nav{display:none}.app-content{padding-bottom:0}}.detail-container{padding:25px;background:#f8fafc;min-height:100vh}.member-summary-card{display:flex;align-items:center;background:#fff;padding:25px;border-radius:20px;box-shadow:0 10px 30px #00000014;margin-bottom:30px;border:1px solid rgba(255,255,255,.8);position:relative;overflow:hidden}.member-summary-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2)}.member-summary-card img{width:80px;height:80px;border-radius:50%;object-fit:cover;margin-right:25px;border:4px solid #f1f5f9;box-shadow:0 4px 15px #0000001a}.member-summary-info h2{margin:0 0 8px;font-size:1.5rem;font-weight:600;color:#1e293b}.member-summary-info p{margin:0;color:#64748b;font-size:.95rem}.detail-container h2{font-size:1.4rem;margin-bottom:20px;color:#1e293b;font-weight:600;position:relative;padding-left:15px}.detail-container h2:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:25px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px}.measurements-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:25px}.measurement-card{background:#fff;padding:25px;border-radius:16px;box-shadow:0 8px 25px #0000000f;border:1px solid rgba(255,255,255,.8);transition:all .3s ease;position:relative;overflow:hidden}.measurement-card:hover{transform:translateY(-5px);box-shadow:0 15px 35px #0000001a}.measurement-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea,#764ba2)}.measurement-card h3{margin:0 0 20px;font-size:1.1rem;color:#1e293b;text-transform:uppercase;letter-spacing:1px;font-weight:600;display:flex;align-items:center}.measurement-card h3:before{content:"📊";margin-right:10px;font-size:1.2rem}.measurement-card p{margin:8px 0;font-size:1rem;color:#475569;line-height:1.6}.measurement-card strong{color:#1e293b;font-weight:600}.measurement-content{display:flex;flex-direction:column;gap:12px}.measurement-item{background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:15px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #00000008;border:1px solid rgba(255,255,255,.8);transition:all .3s ease}.measurement-item:hover{transform:translate(3px);box-shadow:0 4px 15px #00000014;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.measurement-item span{color:#475569;font-size:.95rem;font-weight:500}.measurement-item strong{color:#1e293b;font-weight:600;font-size:1rem}.no-data{color:#94a3b8;font-style:italic;text-align:center;padding:20px;background:#f8fafc;border-radius:8px;border:2px dashed #cbd5e1}.weight-details{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:12px;padding:20px;margin-top:10px}.detail-item{background:#fff;padding:12px 15px;border-radius:10px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #00000008;border:1px solid rgba(255,255,255,.8);transition:all .3s ease}.detail-item:hover{transform:translate(3px);box-shadow:0 4px 15px #00000014}.detail-item span{color:#475569;font-size:.9rem;font-weight:500}.detail-item strong{color:#1e293b;font-weight:600;font-size:.95rem}@media (max-width: 768px){.detail-container{padding:15px}.member-summary-card{padding:20px;flex-direction:column;text-align:center}.member-summary-card img{margin-right:0;margin-bottom:15px}.measurements-grid{grid-template-columns:1fr;gap:20px}.primary-results{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:10px}.details-grid{grid-template-columns:1fr}.detail-item{padding:10px 12px}.measurement-item{padding:12px;flex-direction:column;text-align:center;gap:5px}.measurement-item span{font-size:.85rem}.measurement-item strong{font-size:.95rem}}.info-state{text-align:center;padding:40px 20px;color:#64748b;font-size:1.1rem;background:#fff;border-radius:16px;box-shadow:0 8px 25px #0000000f;margin:20px}.detail-header{display:flex;align-items:center;background:linear-gradient(135deg,#056cf2,#0549a2);padding:20px;color:#fff;box-shadow:0 4px 20px #0000001a}.back-button{background:#fff3;border:none;font-size:2rem;cursor:pointer;margin-right:20px;color:#fff;line-height:1;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-button:hover{background:#ffffff4d;transform:scale(1.1)}.detail-header h1{font-size:1.4rem;margin:0;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.1)}.tab-navigation{display:grid;grid-template-columns:repeat(2,1fr);background:#fff;border-radius:15px;padding:8px;margin-bottom:20px;box-shadow:0 5px 15px #00000014;border:1px solid #e1e8ed}.tab-button{flex:1;padding:12px 20px;border:none;background:transparent;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;color:#7f8c8d;display:flex;align-items:center;justify-content:center;gap:8px}.tab-button:hover{background:#667eea1a;color:#667eea}.tab-button.active{background:linear-gradient(135deg,#056cf2,#0549a2);color:#fff;box-shadow:0 4px 15px #667eea4d}.member-profile-header{text-align:center;padding:20px;background:#fff;border-radius:15px;margin:20px;box-shadow:0 5px 15px #00000014}.profile-photo{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid #056CF2;margin-bottom:15px;box-shadow:0 4px 15px #0000001a}.member-profile-header h2{font-size:1.8rem;margin:0 0 5px;color:#1e293b}.member-profile-header p{color:#7f8c8d;margin:0}.tab-container{padding:20px}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px;background:#fff;padding:20px;border-radius:12px;box-shadow:0 5px 15px #00000014}.info-item{padding:10px;border-bottom:1px solid #f0f2f5}.info-item span{display:block;color:#7f8c8d;font-size:.9rem;margin-bottom:5px}.info-item strong,.info-item p{font-size:1rem;margin:0;color:#1e293b}.info-item.full-width{grid-column:1 / -1}.history-container{background:#fff;padding:20px;border-radius:15px;box-shadow:0 5px 15px #00000014}.history-group h3{margin:20px 0 15px;font-size:1.2rem;color:#056cf2;border-bottom:2px solid #f0f2f5;padding-bottom:10px;font-weight:600}.appointment-group{margin-bottom:20px;background:#f8fafc;border-radius:12px;padding:15px;border:1px solid #e2e8f0}.appointment-time{font-size:.9rem;color:#64748b;margin-bottom:15px;padding-left:5px;font-weight:500}.measurements-list{display:flex;flex-direction:column;gap:8px}.measurement-row{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;border-radius:10px;cursor:pointer;transition:all .3s ease;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 4px #0000000d}.measurement-row:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);transform:translate(5px);box-shadow:0 4px 12px #0000001a;border-color:#056cf2}.measurement-info{display:flex;flex-direction:column;gap:4px;flex:1}.measurement-name{font-size:.95rem;color:#1e293b;font-weight:500}.measurement-result{font-size:.85rem;color:#64748b;font-weight:600}.measurement-row .arrow{color:#056cf2;font-size:1.2rem;font-weight:700;transition:all .3s ease}.measurement-row:hover .arrow{transform:translate(3px);color:#0549a2}.measurement-details{padding:20px}.measurement-details .detail-item{background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:15px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;box-shadow:0 2px 10px #00000008;border:1px solid rgba(255,255,255,.8);transition:all .3s ease}.measurement-details .detail-item:hover{transform:translate(3px);box-shadow:0 4px 15px #00000014;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.measurement-details .detail-item span{color:#475569;font-size:.95rem;font-weight:500}.measurement-details .detail-item strong{color:#1e293b;font-weight:600;font-size:1rem}.primary-results{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:15px;margin-bottom:20px}.result-item{background:#fff;padding:15px;border-radius:12px;text-align:center;box-shadow:0 4px 15px #0000000d;border:1px solid rgba(255,255,255,.8);transition:all .3s ease}.result-item:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}.result-item span{display:block;font-size:.85rem;color:#64748b;margin-bottom:5px;font-weight:500}.result-item strong{display:block;font-size:1.1rem;color:#1e293b;font-weight:700}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}hr{border:none;height:1px;background:linear-gradient(90deg,transparent,#cbd5e1,transparent);margin:20px 0}@media (max-width: 768px){.detail-header{padding:15px}.back-button{width:40px;height:40px;font-size:1.5rem}.detail-header h1{font-size:1.2rem}.member-profile-header{margin:10px;padding:15px}.profile-photo{width:100px;height:100px}.member-profile-header h2{font-size:1.5rem}.info-grid{grid-template-columns:1fr;padding:15px}.tab-navigation{margin:10px}.tab-button{padding:10px 15px;font-size:.9rem}.history-container{padding:15px}.appointment-group{padding:12px}.measurement-row{padding:10px 12px}.primary-results{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:10px}.details-grid{grid-template-columns:1fr}}@media (max-width: 480px){.detail-header h1{font-size:1.1rem}.member-profile-header h2{font-size:1.3rem}.profile-photo{width:80px;height:80px}.tab-button{font-size:.8rem;padding:8px 12px}.measurement-row{flex-direction:column;align-items:flex-start;gap:8px}.measurement-info{width:100%}.measurement-row .arrow{align-self:flex-end}}
