.notification-bell-container{position:relative}.notification-bell-btn{position:relative;background:none;border:none;padding:8px;cursor:pointer;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.notification-bell-btn:hover{background:#f2f2f7;color:var(--text-primary)}.notification-badge{position:absolute;top:2px;right:2px;background:#ff3b30;color:#fff;font-size:11px;font-weight:600;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.notification-dropdown{position:absolute;top:calc(100% + 12px);right:0;width:400px;max-width:90vw;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f;z-index:1000;animation:slideDown .2s ease;max-height:600px;display:flex;flex-direction:column}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notification-dropdown-header{padding:20px;border-bottom:1px solid #E5E5EA;display:flex;align-items:center;justify-content:space-between}.notification-dropdown-header h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.mark-all-read-btn{background:none;border:none;color:var(--primary-color);font-size:14px;font-weight:500;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s ease}.mark-all-read-btn:hover{background:#f2f2f7}.notification-loading,.notification-empty{padding:40px 20px;text-align:center;color:var(--text-secondary);font-size:15px}.notification-list{overflow-y:auto;max-height:500px}.notification-item{display:flex;gap:12px;padding:16px 20px;border-bottom:1px solid #F2F2F7;cursor:pointer;transition:all .2s ease;position:relative}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:#f8f8f9}.notification-item.unread{background:#f0f4ff}.notification-item.unread:hover{background:#e8eeff}.notification-icon{font-size:24px;line-height:1;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:4px}.notification-title{font-size:15px;font-weight:600;color:var(--text-primary)}.notification-time{font-size:12px;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.notification-body{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5;word-wrap:break-word}.unread-dot{width:8px;height:8px;background:var(--primary-color);border-radius:50%;flex-shrink:0;margin-top:2px}@media(max-width:768px){.notification-dropdown{width:320px}.notification-dropdown-header h3{font-size:18px}.notification-item{padding:12px 16px}}.error-alert{background:linear-gradient(135deg,#fff5f5,#ffe5e5);border:1px solid #ff6b6b;border-radius:12px;padding:16px;margin:16px 0;box-shadow:0 2px 8px #ff6b6b1a;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-alert-content{display:flex;flex-direction:column;gap:12px}.error-alert-header{display:flex;align-items:center;gap:12px}.error-alert-icon{width:24px;height:24px;color:#ff6b6b;flex-shrink:0}.error-alert-title{flex:1;margin:0;font-size:16px;font-weight:600;color:#c92a2a}.error-alert-close{background:none;border:none;padding:4px;cursor:pointer;color:#868e96;transition:color .2s;width:24px;height:24px;flex-shrink:0}.error-alert-close:hover{color:#495057}.error-alert-close svg{width:16px;height:16px}.error-alert-description{margin:0;font-size:14px;line-height:1.5;color:#862e2e}.error-alert-action{display:flex;align-items:flex-start;gap:8px;margin:0;padding:12px;background:#fff9;border-radius:8px;font-size:13px;line-height:1.5;color:#5f3232;border-left:3px solid #ff8787}.error-alert-action-icon{width:18px;height:18px;color:#ff8787;flex-shrink:0;margin-top:1px}.error-alert-technical{margin:8px 0 0;padding:8px 12px;background:#0000000d;border-radius:6px;font-size:12px}.error-alert-technical summary{cursor:pointer;font-weight:500;color:#862e2e;-webkit-user-select:none;user-select:none}.error-alert-technical summary:hover{color:#c92a2a}.error-alert-technical code{display:block;margin-top:8px;padding:8px;background:#0000000d;border-radius:4px;font-family:Monaco,Courier New,monospace;font-size:11px;color:#495057;overflow-x:auto;white-space:pre-wrap;word-break:break-all}@media(max-width:768px){.error-alert{padding:14px;margin:12px 0}.error-alert-title{font-size:15px}.error-alert-description{font-size:13px}.error-alert-action{font-size:12px;padding:10px}}.page-content{background:#fff;min-height:100vh}.specialty-filter-container{padding:16px 16px 20px;background:#fff;border-bottom:1px solid #e0e0e0;position:sticky;top:60px;z-index:10;margin-bottom:24px}.specialty-filter-badges{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.specialty-filter-badge{padding:8px 16px;border:1.5px solid #e0e0e0;border-radius:20px;background:#fff;color:#616161;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;outline:none}.specialty-filter-badge:hover{border-color:var(--specialty-color, #5B5FC7);background:#f2f2f7;color:var(--specialty-color, #5B5FC7);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.specialty-filter-badge.active{background:var(--specialty-color, #5B5FC7);color:#fff;border-color:var(--specialty-color, #5B5FC7);box-shadow:0 2px 8px #5b5fc74d}.specialty-filter-badge.active:first-child{background:#5b5fc7;border-color:#5b5fc7;--specialty-color: #5B5FC7}.specialty-filter-badge:active{transform:translateY(0)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#2196f3;border-radius:50%;animation:spin .8s linear infinite}.loading-state p{color:#757575;font-size:14px}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.error-state p{color:#d32f2f;font-size:14px;text-align:center}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;color:#9e9e9e}.empty-state svg{opacity:.5}.empty-state p{font-size:18px;font-weight:500;color:#616161;margin:0}.empty-state span{font-size:14px;color:#9e9e9e}.doctors-list{padding:0 16px 80px}.specialty-group{margin-bottom:32px}.specialty-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.specialty-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.specialty-title{flex:1;font-size:20px;font-weight:600;color:#212121;margin:0}.specialty-count{background:#fff;color:#616161;font-size:14px;font-weight:500;padding:4px 12px;border-radius:12px;min-width:32px;text-align:center}.specialty-doctors{display:flex;flex-direction:column;gap:12px}.doctor-card{background:#fff;border:1px solid #e0e0e0;border-radius:16px;padding:16px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:all .2s}.doctor-card:hover{border-color:#2196f3;box-shadow:0 4px 12px #2196f31a;transform:translateY(-2px)}.doctor-card:active{transform:translateY(0)}.doctor-photo{width:56px;height:56px;border-radius:50%;background:#e3f2fd;color:#2196f3;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;transition:all .2s}.doctor-card:hover .doctor-photo{transform:scale(1.05)}.doctor-photo img{width:100%;height:100%;object-fit:cover}.doctor-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:#2196f3;background:linear-gradient(135deg,#e3f2fd,#bbdefb);text-transform:uppercase;letter-spacing:1px}.doctor-avatar-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.doctor-card:nth-child(6n+1) .doctor-avatar-fallback{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1976d2}.doctor-card:nth-child(6n+2) .doctor-avatar-fallback{background:linear-gradient(135deg,#f3e5f5,#e1bee7);color:#7b1fa2}.doctor-card:nth-child(6n+3) .doctor-avatar-fallback{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#388e3c}.doctor-card:nth-child(6n+4) .doctor-avatar-fallback{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#f57c00}.doctor-card:nth-child(6n+5) .doctor-avatar-fallback{background:linear-gradient(135deg,#fce4ec,#f8bbd0);color:#c2185b}.doctor-card:nth-child(6n+6) .doctor-avatar-fallback{background:linear-gradient(135deg,#e0f2f1,#b2dfdb);color:#00796b}.doctor-info{flex:1;min-width:0}.doctor-name{font-size:16px;font-weight:500;color:#212121;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doctor-experience{font-size:14px;color:#757575;margin:0}.doctor-arrow{color:#bdbdbd;font-size:24px;line-height:1;flex-shrink:0}@media(max-width:768px){.specialty-filter-container{top:56px;padding:12px}.specialty-filter-badge{padding:6px 12px;font-size:13px}.doctors-list{padding:12px}.specialty-group{margin-bottom:24px}.specialty-icon{width:40px;height:40px}.specialty-title{font-size:18px}.doctor-card{padding:12px;gap:12px}.doctor-photo{width:48px;height:48px}.doctor-name{font-size:15px}.doctor-experience{font-size:13px}}.specialty-group{animation:fadeIn .3s ease-out}.specialty-group:nth-child(1){animation-delay:.05s}.specialty-group:nth-child(2){animation-delay:.1s}.specialty-group:nth-child(3){animation-delay:.15s}.specialty-group:nth-child(4){animation-delay:.2s}.specialty-group:nth-child(5){animation-delay:.25s}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #5B5FC7;--primary-dark: #4A4FB0;--primary-light: #6B6FD7;--background: #FFFFFF;--card-bg: #FFFFFF;--card-dark: #4E5D78;--text-primary: #000000;--text-secondary: #666666;--text-light: #FFFFFF;--border-color: #E0E0E0;--accent-orange: #FF8A65;--accent-purple: #BA68C8;--accent-green: #81C784;--accent-blue: #64B5F6}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Helvetica Neue,sans-serif;background:var(--background);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.01em}.app-container{min-height:100vh;background:var(--background);display:flex;flex-direction:column}.top-nav{background:var(--primary-color);border-bottom:none;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:1000;overflow:visible;color:#fff}@supports (padding: max(0px)){@media(max-width:768px){.top-nav{padding-top:max(env(safe-area-inset-top),0px);background:var(--primary-color)}.top-nav:before{content:"";position:absolute;top:0;left:0;right:0;height:max(env(safe-area-inset-top),0px);background:var(--primary-color);z-index:-1}}}@media(max-width:768px){.top-nav{padding-top:env(safe-area-inset-top,0px);background:var(--primary-color)}.top-nav:before{content:"";position:absolute;top:0;left:0;right:0;height:env(safe-area-inset-top,0px);background:var(--primary-color);z-index:-1}}.top-nav-content{max-width:1400px;margin:0 auto;padding:0 32px;height:70px;display:flex;align-items:center;justify-content:space-between;gap:48px}.top-nav-brand{display:flex;align-items:center;justify-content:center;text-decoration:none;transition:opacity .2s ease;overflow:visible;flex-shrink:0}.top-nav-brand svg{display:block;flex-shrink:0}.top-nav-brand:hover{opacity:.9}.top-nav-links{display:flex;gap:8px;flex:1}.top-nav-link{padding:10px 20px;color:#fff;text-decoration:none;font-size:15px;font-weight:400;border-radius:8px;transition:all .2s ease;white-space:nowrap;opacity:.8}.top-nav-link:hover{opacity:1;color:#fff}.top-nav-link.active{background:transparent;color:#fff;font-weight:600;text-decoration:underline;text-underline-offset:6px;text-decoration-thickness:2px;opacity:1}.top-nav-actions{display:flex;align-items:center;gap:24px}.user-info{display:flex;align-items:center;gap:12px;padding:8px 16px;border-radius:24px;background:#f2f2f7}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;color:#fff}.user-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap}.logout-btn-header{display:flex;align-items:center;gap:8px;padding:10px 20px;background:none;border:1px solid #FF3B30;border-radius:8px;color:#ff3b30;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.logout-btn-header:hover{background:#ff3b30;color:#fff}.logout-btn-header:active{transform:scale(.95)}.main-content-web{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:32px}.main-content{flex:1;padding-bottom:80px}.bottom-nav{display:none}.page,.page-no-header{min-height:calc(100vh - 70px);background:transparent}.page.calendar-page{background:transparent}.page-header{display:none}.page-content{background:transparent}@media(max-width:768px){.page-header{display:none!important}}.menu-btn{background:none;border:none;padding:8px;cursor:pointer;color:var(--text-primary);border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.menu-btn:hover{background:#f2f2f7}.menu-btn:active{transform:scale(.95)}.logout-btn{color:#ff3b30}.logout-btn:hover{background:#ff3b301a}.page-content{padding:0;max-width:1200px;margin:0 auto}.section{margin-bottom:32px}.section-title{font-size:22px;font-weight:700;margin-bottom:12px}.section-description{color:var(--text-secondary);font-size:14px;line-height:1.5;margin-bottom:16px}.future-appointments-widget{background:#fff;border-radius:16px;padding:16px;margin-bottom:20px;border:1px solid #E0E0E0;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between;gap:16px}.future-appointments-widget:hover{box-shadow:0 4px 12px #5b5fc71a;transform:translateY(-2px);border-color:var(--primary-color)}.future-appointments-header{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.future-appointments-header svg{color:var(--primary-color);flex-shrink:0}.future-appointments-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.01em}.future-appointments-badges{display:flex;gap:8px;flex-wrap:wrap;flex:1;justify-content:flex-end}.future-appointment-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:12px;font-size:13px;font-weight:500;transition:all .2s ease}.future-appointment-confirmed{background:#e3f2fd;color:#1976d2;border:1px solid #1976D2}.future-appointment-pending{background:#fff3e0;color:#f57c00;border:1px solid #F57C00}.future-appointment-label{font-weight:500;white-space:nowrap}.future-appointment-count{font-weight:700;font-size:14px;min-width:20px;text-align:center}.future-appointments-arrow{color:#bdbdbd;font-size:24px;line-height:1;flex-shrink:0;transition:color .2s ease}.future-appointments-widget:hover .future-appointments-arrow{color:var(--primary-color)}.future-appointments-empty{flex:1;display:flex;justify-content:flex-end;align-items:center}.future-appointments-empty span{font-size:14px;color:var(--text-secondary);font-style:italic}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-card{background:#fff;padding:20px;border-radius:16px;box-shadow:0 1px 3px #0000000f;transition:all .2s ease}.stat-card:active{transform:scale(.98)}.stat-label{font-size:14px;color:var(--text-secondary);margin-bottom:8px}.stat-value{font-size:32px;font-weight:700}.search-box{position:relative;margin-bottom:16px}.search-input{width:100%;padding:14px 16px 14px 48px;border:none;border-radius:16px;font-size:15px;background:#fff;box-shadow:0 2px 8px #0000000f;transition:all .2s}.search-input:focus{outline:none;box-shadow:0 4px 12px #5b5fc726}.calendar-page .search-input{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.search-bar{display:flex;gap:8px;margin-bottom:24px}.search-bar .search-box{flex:1;margin:0}.filter-btn{background:#fff;border:1px solid var(--border-color);border-radius:12px;padding:12px;cursor:pointer}.btn{width:100%;padding:15px 20px;border-radius:14px;font-size:17px;font-weight:600;border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;letter-spacing:-.02em}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#8b8fe7,#6b6fd7);color:#fff;box-shadow:0 2px 12px #6b6fd74d;border:none}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#6b6fd7,#5b5fc7);box-shadow:0 4px 16px #6b6fd766;transform:translateY(-1px)}.btn-primary:active:not(:disabled){box-shadow:0 1px 6px #6b6fd74d;transform:translateY(0)}.btn-with-icon{display:flex;align-items:center;justify-content:center;gap:8px}.btn-danger{background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff;box-shadow:0 2px 12px #ff6b6b4d;border:none}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#ee5a52,#dc4c44);box-shadow:0 4px 16px #ff6b6b66;transform:translateY(-1px)}.btn-danger:active:not(:disabled){box-shadow:0 1px 6px #ff6b6b4d;transform:translateY(0)}.btn-text{background:none;color:var(--primary-color);margin-top:12px;font-weight:500}.btn-text:active{opacity:.6}.articles-list{display:flex;flex-direction:column;gap:12px}.article-card{display:flex;align-items:center;gap:14px;padding:14px;background:#fff;border-radius:16px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000f}.article-card:active{transform:scale(.98);box-shadow:0 1px 2px #00000014}.article-image{font-size:32px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:12px;flex-shrink:0}.article-content{flex:1}.article-title{font-size:16px;font-weight:600;margin-bottom:4px}.home-articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:16px}.home-article-card{background:#fff;border-radius:16px;overflow:hidden;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000000f;border:1px solid #E0E0E0;display:flex;flex-direction:column}.home-article-card:hover{box-shadow:0 4px 16px #5b5fc726;transform:translateY(-2px);border-color:var(--primary-color)}.home-article-card:active{transform:translateY(0)}.home-article-image{width:100%;height:180px;overflow:hidden;background:#f2f2f7;display:flex;align-items:center;justify-content:center}.home-article-image img{width:100%;height:100%;object-fit:cover}.home-article-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#bdbdbd;background:#f9f9f9}.home-article-content{padding:16px;display:flex;flex-direction:column;gap:8px;flex:1}.home-article-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.home-article-preview{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;flex:1}.home-article-rating{display:flex;align-items:center;gap:4px;margin-top:4px;font-size:14px;font-weight:600;color:#ff9800}.home-article-rating svg{flex-shrink:0}.article-description{font-size:13px;color:var(--text-secondary);line-height:1.4}.article-arrow{font-size:24px;color:var(--text-secondary)}.specialty-group{margin-bottom:24px;background:transparent}.specialty-title{font-size:18px;font-weight:600;margin-bottom:12px}.doctors-list{margin-top:16px}.doctor-card{display:flex;align-items:center;gap:14px;padding:14px;background:#fff;border-radius:16px;margin-bottom:10px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000f}.doctor-card:active{transform:scale(.98);box-shadow:0 1px 2px #00000014}.doctor-photo{width:56px;height:56px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.doctor-info{flex:1}.doctor-name{font-size:16px;font-weight:500;margin-bottom:4px}.doctor-specialty{font-size:14px;color:var(--text-secondary)}.doctor-arrow{font-size:24px;color:var(--text-secondary)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden;background:#6b6fd7}.login-page:before,.login-page:after{content:"";position:absolute;border-radius:50%;filter:blur(80px);opacity:.6;animation:wave 15s ease-in-out infinite}.login-page:before{width:500px;height:500px;background:radial-gradient(circle,#BA68C8 0%,transparent 70%);top:-250px;left:-250px;animation-delay:0s}.login-page:after{width:600px;height:600px;background:radial-gradient(circle,#64B5F6 0%,transparent 70%);bottom:-300px;right:-300px;animation-delay:-5s}.wave{position:absolute;border-radius:50%;filter:blur(80px);opacity:.6;animation:wave 12s ease-in-out infinite;z-index:0}.wave-1{width:400px;height:400px;background:radial-gradient(circle,#BA68C8 0%,transparent 70%);top:10%;left:10%;animation-delay:0s}.wave-2{width:500px;height:500px;background:radial-gradient(circle,#64B5F6 0%,transparent 70%);top:50%;right:10%;animation-delay:-1.5s}.wave-3{width:450px;height:450px;background:radial-gradient(circle,#6B6FD7 0%,transparent 70%);bottom:15%;left:20%;animation-delay:-3s}.wave-4{width:350px;height:350px;background:radial-gradient(circle,#FF8A65 0%,transparent 70%);top:30%;right:30%;animation-delay:-4.5s}.wave-5{width:480px;height:480px;background:radial-gradient(circle,#81D4FA 0%,transparent 70%);top:5%;right:15%;animation-delay:-6s}.wave-6{width:380px;height:380px;background:radial-gradient(circle,#FFB74D 0%,transparent 70%);bottom:10%;right:25%;animation-delay:-7.5s}.wave-7{width:420px;height:420px;background:radial-gradient(circle,#F06292 0%,transparent 70%);top:60%;left:5%;animation-delay:-9s}.wave-8{width:360px;height:360px;background:radial-gradient(circle,#4DD0E1 0%,transparent 70%);bottom:5%;left:50%;animation-delay:-10.5s}@keyframes wave{0%,to{transform:translate(0) scale(1);opacity:.7}25%{transform:translate(80px,50px) scale(1.3);opacity:.9}50%{transform:translate(-60px,80px) scale(.7);opacity:.5}75%{transform:translate(50px,-50px) scale(1.2);opacity:.8}}.login-container{width:100%;max-width:400px;position:relative;z-index:1}.login-logo{filter:drop-shadow(0 2px 8px rgba(0,0,0,.2))}.login-header{text-align:center;color:#fff;margin-bottom:32px}.login-header h1{font-size:32px;margin-bottom:8px}.login-header p{font-size:16px;opacity:.9}.login-form{background:#fff;padding:32px 24px;border-radius:24px;box-shadow:0 8px 32px #0000001f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-form h2{font-size:24px;margin-bottom:8px}.form-description{color:var(--text-secondary);font-size:14px;margin-bottom:24px}.pwa-install-tooltip-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:10001;padding:20px;animation:fadeIn .3s ease-out}.pwa-install-tooltip{background:#f5f5f7;border-radius:20px;max-width:400px;width:100%;position:relative;box-shadow:0 8px 32px #0003;animation:slideUpTooltip .3s ease-out;overflow:hidden}@keyframes slideUpTooltip{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.pwa-install-tooltip-close{position:absolute;top:12px;right:12px;background:#0000001a;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;color:var(--text-secondary);transition:all .2s ease;z-index:1;line-height:1;padding:0}.pwa-install-tooltip-close:hover{background:#00000026;color:var(--text-primary)}.pwa-install-tooltip-close:active{transform:scale(.95)}.pwa-install-tooltip-content{padding:32px 24px 28px;text-align:center}.pwa-install-tooltip-title{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 24px;line-height:1.2;letter-spacing:-.02em}.pwa-install-tooltip-steps{display:flex;flex-direction:column;gap:20px;text-align:left}.pwa-install-tooltip-step{display:flex;align-items:flex-start;gap:12px}.pwa-install-tooltip-step-number{font-size:18px;font-weight:700;color:var(--text-primary);flex-shrink:0;line-height:1.4}.pwa-install-tooltip-step-text{font-size:16px;font-weight:500;color:var(--text-primary);line-height:1.5;flex:1}.pwa-install-tooltip-step-text strong{font-weight:700;color:var(--primary-color)}.pwa-install-tooltip-share-icon{display:inline-block;background:var(--text-primary);color:#f5f5f7;padding:4px 8px;border-radius:6px;font-size:14px;font-weight:700;margin:0 2px;vertical-align:middle;line-height:1.2}.pwa-install-tooltip-menu-icon{display:inline-block;background:var(--text-primary);color:#f5f5f7;padding:4px 10px;border-radius:6px;font-size:18px;font-weight:700;margin:0 2px;vertical-align:middle;line-height:1.2}@media(max-width:768px){.pwa-install-tooltip-overlay{padding:16px}.pwa-install-tooltip{max-width:100%;border-radius:16px}.pwa-install-tooltip-content{padding:28px 20px 24px}.pwa-install-tooltip-title{font-size:24px;margin-bottom:20px}.pwa-install-tooltip-steps{gap:16px}.pwa-install-tooltip-step-text{font-size:15px}}.form-group label{display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-input{width:100%;padding:15px 16px;border:none;border-radius:12px;font-size:17px;background:#f2f2f7;font-family:inherit;transition:all .2s ease;letter-spacing:-.01em}.form-input::placeholder{color:#8e8e93}.form-input:focus{outline:none;background:#e5e5ea;box-shadow:0 0 0 3px #5b5fc71a}.form-input:hover:not(:focus){background:#ebebf0}.otp-input{text-align:center;font-size:24px;letter-spacing:8px;font-weight:600}.form-input[type=tel]{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,sans-serif;font-variant-numeric:tabular-nums;letter-spacing:.5px}.phone-input-centered{text-align:center;font-size:20px;font-weight:500;letter-spacing:1px}.phone-input-centered::placeholder{color:#d1d1d6;letter-spacing:3px;font-weight:400}.form-input-date,.form-input[type=date]{accent-color:var(--primary-color);color-scheme:light;cursor:pointer}.checkbox-group{margin-bottom:24px}.checkbox-label,.form-group .checkbox-label,.checkbox-group .checkbox-label{display:flex!important;align-items:flex-start;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-input{width:20px;height:20px;min-width:20px;border-radius:6px;border:2px solid #D1D1D6;background:#fff;cursor:pointer;transition:all .2s ease;appearance:none;-webkit-appearance:none;position:relative;margin-top:2px;flex-shrink:0}.checkbox-input:checked{background:var(--primary-color);border-color:var(--primary-color)}.checkbox-input:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:600}.checkbox-input:hover:not(:checked){border-color:#a8a8a8}.checkbox-input:focus{outline:none;box-shadow:0 0 0 3px #5b5fc71a}.checkbox-text{font-size:13px;line-height:1.5;color:var(--text-secondary);flex:1}.required-asterisk{color:#ff3b30;font-weight:600}.support-request-success-check{font-size:48px;margin-bottom:16px;color:var(--accent-green)}.policy-link{color:var(--primary-color);text-decoration:none;font-weight:500;transition:all .2s ease;border-bottom:1px solid var(--primary-color)}.policy-link:hover{color:var(--primary-dark);border-bottom-color:var(--primary-dark)}.policy-link:active{opacity:.7}.error-message{padding:12px;background:#ffebee;color:#c62828;border-radius:8px;font-size:14px;margin-bottom:16px}.tabs{display:flex;gap:8px;margin-bottom:16px}.tab{flex:1;padding:12px;background:#fff;border:1px solid var(--border-color);border-radius:8px;font-size:14px;cursor:pointer}.tab.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.empty-state{text-align:center;padding:48px 20px;color:var(--text-secondary)}.consultations-list{margin-top:16px}.consultation-card{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:12px;margin-bottom:8px;cursor:pointer;transition:background .2s}.consultation-card:active{background:#f8f8f8}.consultation-icon{width:56px;height:56px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.consultation-info{flex:1}.consultation-specialty{font-size:16px;font-weight:500;margin-bottom:4px}.consultation-date{font-size:14px;color:var(--text-secondary)}.consultation-arrow{font-size:24px;color:var(--text-secondary)}.calendar-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:0 4px}.view-mode-selector{flex:1}.view-mode-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;color:#fff;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.view-mode-btn:hover{background:#ffffff40}.month-navigation{display:flex;gap:8px}.nav-btn{padding:10px;background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-btn:hover{background:#ffffff40;transform:scale(1.05)}.calendar{background:linear-gradient(135deg,#4e5d78,#5b6b88);border-radius:20px;padding:24px;margin-bottom:24px;box-shadow:0 8px 24px #00000026;color:var(--text-light)}.calendar-month{font-size:24px;font-weight:700;margin-bottom:20px;color:var(--text-light);text-align:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-weekday{text-align:center;font-size:11px;color:#fff9;padding:8px 4px;font-weight:600;text-transform:uppercase}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:15px;border-radius:50%;cursor:pointer;transition:all .3s ease;color:#ffffffe6;font-weight:500;position:relative}.calendar-day:hover{background:#ffffff1a;transform:scale(1.05)}.calendar-day.other-month{color:#ffffff4d}.calendar-day.today{border:1px solid var(--primary-color)}.calendar-day.today.selected{background:var(--primary-color)!important;color:#fff!important;border:none!important}.calendar-day.selected{background:var(--primary-color)!important;color:#fff!important;font-weight:700;box-shadow:0 4px 12px #5b5fc766;transform:scale(1.1);border:none!important}.calendar-day.has-event:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--accent-orange)}.appointments-page .page-content{padding:16px}@media(min-width:769px){.appointments-desktop-layout{display:flex;gap:24px;align-items:flex-start}.appointments-left-column{flex:0 0 35%;display:flex;flex-direction:column;gap:24px}.appointments-right-column{flex:0 0 65%;display:flex;flex-direction:column;gap:16px}.appointments-calendar-container{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f;margin-bottom:0}.appointments-calendar-container .booking-calendar{width:100%}.appointments-status-table{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f;margin-bottom:0}.appointments-status-table .status-table-body{display:flex;flex-direction:column;gap:12px}.appointments-status-table .status-table-row{padding:12px 16px}.active-filter-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:0}.appointments-list-container{flex:1}}@media(max-width:768px){.appointments-desktop-layout{display:flex;flex-direction:column;gap:16px}.appointments-left-column,.appointments-right-column{width:100%}}.appointments-calendar-container{display:flex;gap:24px;max-width:900px;margin:0 auto 24px;background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f}.appointments-calendar-container .booking-calendar{flex:1;min-width:0}.appointments-status-table{flex:1;background:#f8f9fa;border-radius:16px;padding:20px;display:flex;flex-direction:column}.status-table-header{margin-bottom:12px}.status-table-header h4{font-size:15px;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.01em}.status-table-body{display:flex;flex-direction:column;gap:12px}.status-table-body.status-table-horizontal{display:flex;flex-direction:row;gap:8px;flex-wrap:wrap}.status-table-row{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:#fff;border-radius:8px;transition:all .2s ease;flex:1;min-width:0}.status-table-row:hover{box-shadow:0 2px 6px #0000000f;transform:translateY(-1px)}.status-table-row.active{box-shadow:0 2px 8px #00000026}.status-table-row.active-pending{background:#fff3e0;color:#f57c00}.status-table-row.active-pending .status-table-label,.status-table-row.active-pending .status-table-label span,.status-table-row.active-pending .status-icon,.status-table-row.active-pending .status-table-count{color:#f57c00}.status-table-row.active-confirmed{background:#e3f2fd;color:#1976d2}.status-table-row.active-confirmed .status-table-label,.status-table-row.active-confirmed .status-table-label span,.status-table-row.active-confirmed .status-icon,.status-table-row.active-confirmed .status-table-count{color:#1976d2}.status-table-row.active-completed{background:#e8f5e9;color:#388e3c}.status-table-row.active-completed .status-table-label,.status-table-row.active-completed .status-table-label span,.status-table-row.active-completed .status-icon,.status-table-row.active-completed .status-table-count{color:#388e3c}.status-table-row.active-cancelled{background:#ffebee;color:#d32f2f}.status-table-row.active-cancelled .status-table-label,.status-table-row.active-cancelled .status-table-label span,.status-table-row.active-cancelled .status-icon,.status-table-row.active-cancelled .status-table-count{color:#d32f2f}@media(max-width:768px){.status-table-row.active-pending{background:#fff3e080;border:1px solid #FFF3E0}.status-table-row.active-confirmed{background:#e3f2fd80;border:1px solid #E3F2FD}.status-table-row.active-completed{background:#e8f5e980;border:1px solid #E8F5E9}.status-table-row.active-cancelled{background:#ffebee80;border:1px solid #FFEBEE}}.status-table-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--text-primary)}.status-table-label span{letter-spacing:-.01em;white-space:nowrap}.status-table-count{font-size:14px;font-weight:700;color:var(--primary-color);min-width:20px;text-align:right;margin-left:8px}.status-table-total{margin-top:4px;padding-top:14px;border-top:2px solid #E5E5EA;background:#f8f9fa}.status-table-total .status-table-label{font-weight:600;color:var(--text-primary)}.status-table-total .status-table-count{color:var(--text-primary);font-size:18px}.appointments-tabs{display:flex;gap:8px;margin-bottom:24px;background:#fff;padding:4px;border-radius:12px;box-shadow:0 1px 3px #00000014}.appointments-tab{flex:1;padding:12px 20px;border:none;border-radius:8px;background:transparent;font-size:15px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.appointments-tab.active{background:var(--primary-color);color:#fff;font-weight:600}.appointments-tab:hover:not(.active){background:#f2f2f7;color:var(--text-primary)}.appointments-list-container{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f}.appointments-items{display:flex;flex-direction:column;gap:12px}.appointment-item-card{padding:20px;background:#f9f9f9;border-radius:16px;border:1px solid #E0E0E0;transition:all .2s ease;display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.appointment-item-card:hover{background:#fff;border-color:var(--primary-color);box-shadow:0 2px 8px #5b5fc71a}.appointment-item-info{display:flex;flex-direction:column;gap:8px;flex:1;min-width:0}.appointment-item-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.appointment-item-date,.appointment-item-date-time{font-size:16px;font-weight:600;color:var(--text-primary)}.appointment-item-time{font-size:14px;color:var(--text-secondary);font-weight:500}.appointment-item-doctor{font-size:16px;font-weight:500;color:var(--text-primary);margin-top:4px}.appointment-item-status{margin-top:8px;display:flex;align-items:center;gap:8px}.appointment-status-text{font-size:14px;font-weight:500}.appointment-status-text.status-pending{color:#f57c00}.appointment-status-text.status-confirmed{color:#1976d2}.appointment-status-text.status-completed{color:#388e3c}.appointment-status-text.status-cancelled{color:#d32f2f}.status-icon{flex-shrink:0}.status-icon-pending{color:#ffb300}.status-icon-confirmed{color:#1976d2}.status-icon-completed{color:#388e3c}.status-icon-cancelled{color:#d32f2f}.status-badge{display:inline-block;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:500;letter-spacing:-.01em}.status-badge.status-pending{background:#fff3e0;color:#f57c00}.status-badge.status-confirmed{background:#e3f2fd;color:#1976d2}.status-badge.status-completed{background:#e8f5e9;color:#388e3c}.status-badge.status-cancelled{background:#ffebee;color:#d32f2f}.appointment-item-notes{display:flex;align-items:flex-start;gap:6px;margin-top:8px;font-size:13px;color:var(--text-secondary)}.appointment-item-notes svg{flex-shrink:0;color:var(--text-secondary)}.appointment-item-files{display:flex;align-items:center;gap:4px;margin-top:8px;font-size:13px;color:var(--text-secondary);padding:6px 10px;background:#f2f2f7;border-radius:8px}.appointment-item-files svg{flex-shrink:0;color:var(--primary-color)}.appointment-view-files-btn{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;width:28px;height:28px;padding:0;border:none;border-radius:6px;background:#f2f2f7;color:var(--text-primary);cursor:pointer;transition:all .2s ease;flex-shrink:0}.appointment-view-files-btn:hover{background:#e5e5ea;color:var(--primary-color);transform:translateY(-1px)}.appointment-view-files-btn:active{transform:translateY(0)}.appointment-item-actions{display:flex;gap:8px;flex-shrink:0}.appointment-action-btn{width:36px;height:36px;border-radius:8px;border:none;background:#f2f2f7;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.appointment-action-btn:hover{background:#e5e5ea;transform:scale(1.05)}.appointment-edit-btn:hover{background:#e3f2fd;color:var(--primary-color)}.appointment-cancel-btn:hover{background:#ffebee;color:#d32f2f}.appointment-files-modal{max-width:600px}.appointment-files-list{display:flex;flex-direction:column;gap:12px}.appointment-file-item{display:flex;align-items:center;gap:12px;padding:16px;background:#f2f2f7;border-radius:12px;transition:all .2s ease}.appointment-file-item:hover{background:#e5e5ea}.appointment-file-icon{flex-shrink:0;width:48px;height:48px;background:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.appointment-file-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.appointment-file-name{font-size:14px;font-weight:500;color:var(--text-primary);word-break:break-word}.appointment-file-size{font-size:12px;color:var(--text-secondary)}.appointment-file-actions{display:flex;gap:8px;flex-shrink:0}.appointment-file-view-btn,.appointment-file-download-btn,.appointment-file-delete-btn{width:36px;height:36px;border-radius:8px;border:none;background:#fff;color:var(--primary-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;text-decoration:none}.appointment-file-view-btn:hover,.appointment-file-download-btn:hover{background:var(--primary-color);color:#fff;transform:scale(1.05)}.appointment-file-delete-btn{color:#d32f2f}.appointment-file-delete-btn:hover{background:#ffebee;color:#c62828;transform:scale(1.05)}.appointment-file-delete-btn:disabled{opacity:.5;cursor:not-allowed}.appointment-file-view-btn:active,.appointment-file-download-btn:active,.appointment-file-delete-btn:active{transform:scale(.95)}.appointments-list{margin-bottom:24px}.appointment-card{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#fff;border-radius:16px;margin-bottom:12px;box-shadow:0 2px 8px #00000014;border-left:4px solid var(--primary-color);transition:all .2s ease;position:relative}.appointment-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.appointment-card.event-type-meeting{border-left-color:var(--accent-orange)}.appointment-card.event-type-consultation{border-left-color:var(--accent-purple)}.appointment-card.event-type-break{border-left-color:var(--accent-green);background:#fff}.appointment-icon{width:56px;height:56px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.appointment-info{flex:1}.appointment-specialty{font-size:16px;font-weight:500;margin-bottom:4px}.appointment-datetime{font-size:14px;color:var(--text-secondary)}.appointment-menu{padding:8px;background:none;border:none;cursor:pointer;color:var(--text-secondary)}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 0}.pagination-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border-color);border-radius:8px;cursor:pointer}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.pagination-number{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border-color);border-radius:8px;font-weight:500}.pagination-number.inactive{color:var(--text-secondary);background:#f8f8f8}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--background);color:var(--text-secondary)}.doctor-detail-card{background:#fff;border-radius:12px;padding:24px;text-align:center}.doctor-detail-photo{width:120px;height:120px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:60px;margin:0 auto 16px;overflow:hidden;flex-shrink:0}.doctor-detail-photo img{width:100%;height:100%;object-fit:cover}.doctor-detail-photo .doctor-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:600;text-transform:uppercase;letter-spacing:1px}.doctor-detail-name{font-size:20px;font-weight:600;margin-bottom:8px}.doctor-detail-specialty{font-size:16px;color:var(--primary-color);margin-bottom:24px}.doctor-info-section{text-align:left;margin-bottom:20px;padding-top:16px;border-top:1px solid var(--border-color)}.info-section-title{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.info-section-text{font-size:15px;line-height:1.6;color:var(--text-primary)}.booking-doctor-card{background:#fff;border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;margin-bottom:24px}.doctor-photo-small{width:56px;height:56px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.booking-form{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 16px #00000014}.form-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.form-select{width:100%;padding:15px 40px 15px 16px;border:none;border-radius:12px;font-size:17px;background:#f2f2f7;cursor:pointer;margin-bottom:20px;font-family:inherit;letter-spacing:-.01em;color:var(--text-primary);transition:all .2s ease;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238E8E93' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:20px}.form-select:hover:not(:focus){background-color:#ebebf0}.form-select:focus{outline:none;background-color:#e5e5ea;box-shadow:0 0 0 3px #5b5fc71a}.form-select option{background:#fff;color:var(--text-primary);padding:12px}.time-slots-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}.time-slot{padding:16px 12px;border:none;border-radius:12px;background:#f2f2f7;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:center;letter-spacing:-.01em}.time-slot:hover:not(.selected){background:#e5e5ea;transform:translateY(-1px)}.time-slot:active{transform:scale(.98)}.time-slot.selected{background:var(--primary-color);color:#fff;font-weight:600;box-shadow:0 2px 8px #5b5fc74d;transform:translateY(-1px)}.form-textarea{width:100%;padding:15px 16px;border:none;border-radius:12px;font-size:17px;font-family:inherit;resize:vertical;margin-bottom:8px;background:#f2f2f7;transition:all .2s ease;letter-spacing:-.01em;line-height:1.5}.form-textarea::placeholder{color:#8e8e93}.form-textarea:hover:not(:focus){background:#ebebf0}.form-textarea:focus{outline:none;background:#e5e5ea;box-shadow:0 0 0 3px #5b5fc71a}.character-count{display:block;text-align:right;font-size:12px;color:var(--text-secondary);margin-bottom:20px}.booking-page{max-width:1000px;margin:0 auto;padding:32px 24px}.booking-doctor-header{background:#fff;border-radius:20px;padding:24px;display:flex;align-items:center;gap:20px;margin-bottom:24px;box-shadow:none}.doctor-avatar-large{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#e3f2fd,#bbdefb);display:flex;align-items:center;justify-content:center;font-size:36px;flex-shrink:0;box-shadow:0 4px 12px #5b5fc740;overflow:hidden;position:relative}.doctor-avatar-large img{width:100%;height:100%;object-fit:cover}.doctor-avatar-large .doctor-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:600;color:#1976d2;text-transform:uppercase;letter-spacing:1px}.doctor-avatar-large svg{width:40px;height:40px;color:#1976d2}.booking-doctor-name{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 4px;letter-spacing:-.02em}.booking-doctor-specialty{font-size:15px;color:var(--text-secondary);margin:0 0 4px;font-weight:500}.booking-doctor-experience{font-size:14px;color:var(--text-tertiary);margin:0;font-weight:400}.booking-form-layout{display:flex;flex-direction:column;gap:24px}.booking-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}.booking-section{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f}.booking-section-title{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 16px;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.booking-calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;width:100%;position:relative;padding:0}.booking-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.booking-calendar-weekday{text-align:center;font-size:11px;color:#8e8e93;padding:8px 4px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.booking-calendar-day{aspect-ratio:1;border:none;border-radius:12px;background:#f2f2f7;font-size:14px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;letter-spacing:-.01em}.booking-calendar-day:hover:not(.disabled):not(.other-month){background:#e5e5ea;transform:scale(1.05)}.booking-calendar-day:active:not(.disabled){transform:scale(.95)}.booking-calendar-day.other-month{color:#c7c7cc;background:transparent}.booking-calendar-day.disabled{color:#d1d1d6;background:#fafafa;cursor:not-allowed;opacity:.5}.booking-calendar-day.today{border:1px solid var(--primary-color)}.booking-calendar-day.today.selected{background:var(--primary-color)!important;color:#fff!important;border:none!important}.booking-calendar-day.selected{background:var(--primary-color)!important;color:#fff!important;font-weight:700;box-shadow:0 4px 12px #5b5fc759;transform:scale(1.05);border:none!important}.booking-calendar-day.selected:hover{transform:scale(1.08)}.booking-time-slots{display:flex;flex-direction:column;gap:10px}.booking-time-slot{padding:12px 16px;border:none;border-radius:12px;background:#f2f2f7;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);letter-spacing:-.01em;color:var(--text-primary);display:flex;align-items:center;gap:8px}.booking-time-slot:hover{background:#e5e5ea;transform:translateY(-1px)}.booking-time-slot:active{transform:scale(.98)}.booking-time-slot.selected{background:var(--primary-color);color:#fff;font-weight:600;box-shadow:0 4px 12px #5b5fc74d}.time-slot-icon{flex-shrink:0}.time-slot-label{font-weight:600;min-width:45px}.time-slot-time{font-size:13px;opacity:.8;font-weight:400}.booking-no-selection,.booking-loading,.booking-error-message{padding:32px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px}.booking-no-selection p,.booking-loading p{font-size:14px;color:var(--text-secondary);margin:12px 0 0}.booking-error-message p{font-size:14px;color:#ff3b30;margin:0;font-weight:500}.booking-loading .spinner{border:3px solid #F2F2F7;border-top-color:var(--primary-color);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.booking-notes{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f}.booking-notes-label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:12px;letter-spacing:-.01em}.required-mark{color:#ff3b30;margin-left:2px}.booking-notes-textarea{width:100%;padding:16px;border:none;border-radius:12px;background:#f2f2f7;font-size:15px;font-family:inherit;color:var(--text-primary);resize:vertical;min-height:100px;letter-spacing:-.01em;line-height:1.5;transition:all .2s ease}.booking-notes-textarea:focus{outline:none;background:#e5e5ea;box-shadow:0 0 0 3px #5b5fc71a}.booking-notes-textarea::placeholder{color:#8e8e93}.booking-notes-count{display:block;text-align:right;font-size:12px;color:var(--text-secondary);margin-top:8px}.booking-files{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f}.booking-files-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px;letter-spacing:-.01em}.booking-files-hint{font-size:13px;color:var(--text-secondary);margin-bottom:16px;line-height:1.5}.file-input-hidden{display:none}.file-upload-button{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border:2px dashed #D1D1D6;border-radius:12px;background:#f2f2f7;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;letter-spacing:-.01em}.file-upload-button:hover{background:#e5e5ea;border-color:var(--primary-color);color:var(--primary-color)}.uploaded-files-list{margin-top:16px;display:flex;flex-direction:column;gap:10px}.uploaded-file-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f2f2f7;border-radius:12px;transition:all .2s ease}.uploaded-file-item:hover{background:#e5e5ea}.uploaded-file-icon{flex-shrink:0;width:40px;height:40px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.uploaded-file-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.uploaded-file-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.uploaded-file-size{font-size:12px;color:var(--text-secondary)}.uploaded-file-remove{flex-shrink:0;width:32px;height:32px;border:none;border-radius:50%;background:#fff;color:#ff3b30;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.uploaded-file-remove:hover{background:#ff3b30;color:#fff;transform:scale(1.1)}.uploaded-file-remove:active{transform:scale(.95)}.booking-checkbox{background:#fff;border-radius:20px;padding:20px 24px;box-shadow:0 2px 12px #0000000f}.booking-submit-btn{width:100%;padding:18px 24px;border:none;border-radius:16px;background:linear-gradient(135deg,var(--primary-color),var(--primary-light));color:#fff;font-size:17px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);letter-spacing:-.01em;box-shadow:0 4px 16px #5b5fc74d}.booking-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #5b5fc766}.booking-submit-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #5b5fc74d}.booking-submit-btn:disabled{opacity:.5;cursor:not-allowed}.confirmation-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirmation-modal{background:#fff;border-radius:24px;max-width:480px;width:100%;box-shadow:0 8px 32px #00000026;animation:slideUp .3s ease-out;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirmation-modal-header{padding:32px 32px 24px;text-align:center;border-bottom:1px solid var(--border-color)}.confirmation-icon{color:var(--primary-color);margin-bottom:16px;animation:scaleIn .3s ease-out .1s both}.confirmation-icon-success{color:var(--accent-green);animation:scaleInSuccess .4s ease-out .1s both}@keyframes scaleInSuccess{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.confirmation-modal-success{animation:slideUpSuccess .4s ease-out}@keyframes slideUpSuccess{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.confirmation-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em}.confirmation-modal-content{padding:24px 32px}.confirmation-details{background:#f8f9fa;border-radius:12px;padding:20px;margin-bottom:20px}.confirmation-detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #E9ECEF}.confirmation-detail-row:last-child{border-bottom:none;padding-bottom:0}.confirmation-label{font-size:14px;color:var(--text-secondary);font-weight:500}.confirmation-value{font-size:15px;color:var(--text-primary);font-weight:600;text-align:right;max-width:60%}.confirmation-speciality{font-size:14px;color:var(--text-secondary);font-weight:400}.confirmation-message{font-size:14px;color:var(--text-secondary);text-align:center;margin:0;line-height:1.5}.confirmation-modal-footer{padding:20px 32px 32px;border-top:1px solid var(--border-color)}.confirmation-buttons{display:flex;gap:12px}.confirmation-btn{flex:1;padding:16px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.confirmation-btn-primary{background:var(--primary-color);color:#fff;box-shadow:0 2px 8px #5b5fc74d}.confirmation-btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #5b5fc766}.confirmation-btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #5b5fc74d}.confirmation-btn-cancel{background:#f2f2f7;color:var(--text-primary)}.confirmation-btn-cancel:hover:not(:disabled){background:#e5e5ea;transform:translateY(-2px)}.confirmation-btn-cancel:active:not(:disabled){transform:translateY(0)}.confirmation-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.confirmation-success-footer{text-align:center;padding:8px 0}.confirmation-success-text{font-size:14px;color:var(--text-secondary);margin:0;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@media(max-width:768px){.booking-page{padding:16px}.booking-row{grid-template-columns:1fr;gap:16px}.booking-doctor-header{padding:16px}.doctor-avatar-large{width:60px;height:60px;font-size:30px}.booking-doctor-name{font-size:18px}.booking-section{padding:16px}.booking-calendar-grid{gap:4px}.booking-calendar-day{font-size:13px}.appointments-calendar-container{flex-direction:column;max-width:100%}.appointments-status-table{flex:1;width:100%}.program-widget,.confirmation-modal-overlay{padding:16px}.confirmation-modal{max-width:100%;border-radius:20px}.confirmation-modal-header{padding:24px 20px 20px}.confirmation-icon{width:40px;height:40px;margin-bottom:12px}.confirmation-title{font-size:20px}.confirmation-modal-content{padding:20px}.confirmation-details{padding:16px}.confirmation-detail-row{padding:10px 0;flex-direction:column;align-items:flex-start;gap:4px}.confirmation-value{text-align:left;max-width:100%;word-break:break-word}.confirmation-modal-footer{padding:16px 20px 20px}.confirmation-buttons{flex-direction:column;gap:10px}.confirmation-btn{padding:14px 20px;font-size:15px}.program-widget-header h3{font-size:16px}.program-widget-name{font-size:14px;margin-bottom:12px}.program-stats{gap:12px}.program-stat-item{padding:12px}.program-stat-value{font-size:24px}}.inline-calendar{background:#f2f2f7;border-radius:16px;padding:16px;margin-bottom:20px}.inline-calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.calendar-nav-btn{width:36px;height:36px;border-radius:50%;border:none;background:#fff;font-size:24px;font-weight:300;color:var(--primary-color);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 1px 3px #00000014;flex-shrink:0;position:absolute;z-index:1}.calendar-nav-btn:first-of-type{left:0}.calendar-nav-btn:last-of-type{right:0}.calendar-nav-btn:hover{background:var(--primary-light);color:#fff;transform:scale(1.05)}.calendar-nav-btn:active{transform:scale(.95)}.calendar-current-month{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;text-transform:capitalize;letter-spacing:-.01em;flex:1;text-align:center}.inline-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.inline-calendar-weekday{text-align:center;font-size:11px;color:#8e8e93;padding:8px 4px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.inline-calendar-day{aspect-ratio:1;border:none;border-radius:50%;background:#fff;font-size:15px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;box-shadow:0 1px 2px #0000000a;letter-spacing:-.01em}.inline-calendar-day:hover:not(.disabled):not(.other-month){background:#e5e5ea;transform:scale(1.05)}.inline-calendar-day:active:not(.disabled){transform:scale(.95)}.inline-calendar-day.other-month{color:#c7c7cc;background:transparent;box-shadow:none}.inline-calendar-day.disabled{color:#d1d1d6;background:#fafafa;cursor:not-allowed;opacity:.5}.inline-calendar-day.today{border:1px solid var(--primary-color)}.inline-calendar-day.today.selected{background:var(--primary-color)!important;color:#fff!important;border:none!important}.inline-calendar-day.selected{background:var(--primary-color)!important;color:#fff!important;font-weight:700;box-shadow:0 4px 12px #5b5fc759;transform:scale(1.08);border:none!important}.inline-calendar-day.selected:hover{transform:scale(1.1)}.program-widget{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f;border:1px solid #E0E0E0}.program-widget-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;color:var(--primary-color)}.program-widget-header h3{font-size:18px;font-weight:700;margin:0;color:var(--text-primary);letter-spacing:-.01em}.program-widget-name{font-size:15px;font-weight:600;color:var(--primary-color);margin:-8px 0 16px;letter-spacing:-.01em}.program-widget-content{display:flex;flex-direction:column;gap:20px}.program-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}.program-stat-item{padding:16px;background:#fff;border-radius:16px;border:1px solid #E0E0E0;transition:all .2s ease}.program-stat-item:hover{box-shadow:0 4px 12px #5b5fc71a;transform:translateY(-2px)}.program-stat-item-dates{display:flex;align-items:center;justify-content:center}.program-dates-table{width:100%;display:flex;flex-direction:column;gap:12px}.program-date-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.program-date-label{font-size:12px;color:var(--text-secondary);font-weight:500;flex-shrink:0}.program-date-value{font-size:14px;color:var(--text-primary);font-weight:600;text-align:right}.program-stat-label{font-size:13px;color:var(--text-secondary);margin-bottom:8px;font-weight:500;letter-spacing:-.01em}.program-stat-value{font-size:32px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.program-stat-value.highlight{color:var(--primary-color)}.program-progress-container{display:flex;flex-direction:column;gap:12px}.program-progress-bar{width:100%;height:12px;background:#e5e5ea;border-radius:100px;overflow:hidden;position:relative}.program-progress-fill{height:100%;border-radius:100px;transition:width .5s cubic-bezier(.4,0,.2,1),background .3s ease;box-shadow:0 2px 8px #0003}.program-progress-text{font-size:13px;color:var(--text-secondary);font-weight:500;text-align:center;letter-spacing:-.01em}.consultations-summary{background:#fff;border:1px solid var(--border-color);border-radius:16px;padding:20px 24px;box-shadow:0 2px 8px #0000000f;cursor:pointer;transition:all .2s ease}.consultations-summary:hover{box-shadow:0 4px 12px #5b5fc726;transform:translateY(-2px);border-color:var(--primary-color)}.consultations-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.consultations-label{font-size:15px;font-weight:500;color:var(--text-secondary)}.consultations-value{font-size:20px;font-weight:700;color:var(--primary-color)}.consultations-divider{height:1px;background:var(--border-color);margin:8px 0}.profile-info-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 1px 3px #0000000f}.profile-info-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #E5E5EA}.profile-info-row:last-child{border-bottom:none;padding-bottom:0}.profile-info-row:first-child{padding-top:0}.profile-info-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:#f2f2f7;color:var(--primary-color);flex-shrink:0}.profile-info-content{flex:1;min-width:0}.profile-info-label{font-size:13px;color:#8e8e93;margin-bottom:4px}.profile-info-value{font-size:16px;font-weight:500;color:var(--text-primary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:24px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000026;animation:slideUp .3s ease-out;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:22px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em}.confirmation-modal-success .modal-header{justify-content:center;flex-direction:column;text-align:center}.confirmation-modal-success .modal-header h2{margin-top:16px}.modal-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#f2f2f7;color:var(--text-primary)}.modal-body{padding:24px 28px;flex:1;overflow-y:auto}.modal-footer{padding:20px 28px;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end}.feedback-inline{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-height:0}.feedback-inline-form{padding:16px 20px 24px;display:flex;flex-direction:column;flex:1;min-height:0}.feedback-inline-form .form-group{margin-bottom:16px}.feedback-inline-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color);flex-shrink:0}.feedback-inline-actions .btn{min-height:44px}.feedback-inline-success{padding:24px 20px;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.form-group .required-mark{color:#d32f2f}.form-input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:12px;font-size:15px;font-family:inherit;background:#fff;color:var(--text-primary);transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5b5fc71a}.form-textarea{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:12px;font-size:15px;font-family:inherit;background:#fff;color:var(--text-primary);resize:vertical;transition:all .2s ease}.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5b5fc71a}.form-char-count{display:block;text-align:right;font-size:12px;color:var(--text-secondary);margin-top:4px}.form-hint{font-size:13px;color:var(--text-secondary);margin:8px 0 12px;line-height:1.4}.cancel-warning{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.cancel-appointment-info{background:#f8f9fa;border-radius:12px;padding:16px;margin-bottom:20px}.cancel-info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #E9ECEF}.cancel-info-row:last-child{border-bottom:none;padding-bottom:0}.cancel-label{font-size:14px;color:var(--text-secondary);font-weight:500}.cancel-value{font-size:15px;color:var(--text-primary);font-weight:600;text-align:right}.btn{padding:12px 24px;border-radius:12px;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-primary{background:var(--primary-color);color:#fff;box-shadow:0 2px 8px #5b5fc74d}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #5b5fc766}.btn-secondary{background:#f2f2f7;color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:#e5e5ea}.btn-danger{background:#d32f2f;color:#fff;box-shadow:0 2px 8px #d32f2f4d}.btn-danger:hover:not(:disabled){background:#b71c1c;transform:translateY(-2px);box-shadow:0 4px 12px #d32f2f66}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}@media(max-width:768px){.modal-overlay{padding:16px}.modal-content{max-width:100%;border-radius:20px}.modal-header{padding:20px}.modal-header h2{font-size:20px}.modal-body{padding:20px}.modal-footer{padding:16px 20px;flex-direction:column}.modal-footer .btn{width:100%}.appointment-item-card{flex-direction:column}.appointment-item-actions{width:100%;justify-content:flex-end;margin-top:12px}.articles-grid{grid-template-columns:1fr!important;gap:16px!important}.article-card{height:auto!important}}.app-footer{margin-top:auto;padding:16px 32px;background:transparent;border-top:1px solid var(--border-color)}.app-footer-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:8px;font-size:12px;color:#999;font-weight:400}.app-footer-separator{color:#ccc;margin:0 4px}.app-footer-link{color:#999;text-decoration:none;transition:color .2s ease}.app-footer-link:hover{color:var(--primary-color);text-decoration:underline}.hamburger-menu-btn{display:none;background:none;border:none;padding:6px;cursor:pointer;color:#fff;border-radius:8px;transition:all .2s ease;flex-shrink:0;width:40px;height:40px;align-items:center;justify-content:center}.hamburger-menu-btn:hover{background:#fff3}.hamburger-menu-btn:active{transform:scale(.95)}.mobile-page-title{display:none;font-size:17px;font-weight:700;color:#fff;margin:0;flex:1;text-align:center;letter-spacing:-.01em;position:absolute;left:0;right:0;width:100%;pointer-events:none;line-height:1.2}.mobile-menu-backdrop{position:fixed;inset:0;background:#00000080;z-index:9998;animation:fadeIn .2s ease-out}.mobile-menu-drawer{position:fixed;top:0;left:0;width:70%;max-width:320px;height:100vh;background:#fff;z-index:9999;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:2px 0 8px #00000026}.mobile-menu-drawer.open{transform:translate(0)}@media(max-width:768px){.mobile-menu-drawer.mobile-menu-drawer-fullwidth{width:100%;max-width:100%}}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.mobile-menu-header-with-back{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px}.mobile-menu-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em}.mobile-menu-header-with-back .mobile-menu-title{text-align:center}.mobile-menu-back,.mobile-menu-close{background:none;border:none;padding:8px;cursor:pointer;color:var(--text-secondary);border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-menu-back:hover,.mobile-menu-close:hover{background:#f2f2f7;color:var(--text-primary)}.mobile-menu-nav{flex:1;padding:16px 0;overflow-y:auto}.mobile-menu-link{display:flex;align-items:center;gap:16px;padding:16px 20px;color:var(--text-primary);text-decoration:none;font-size:16px;font-weight:500;transition:all .2s ease;border-left:3px solid transparent}.mobile-menu-link:hover{background:#f2f2f7;border-left-color:var(--primary-color)}.mobile-menu-link svg{color:var(--text-secondary);flex-shrink:0}.mobile-menu-link:hover svg{color:var(--primary-color)}.mobile-menu-link-button{width:100%;text-align:left;background:none;border:none;border-left:3px solid transparent;font-family:inherit;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:16px;padding:16px 20px;color:var(--text-primary);transition:all .2s ease}.mobile-menu-link-button:hover{background:#f2f2f7;border-left-color:var(--primary-color)}.mobile-menu-link-button svg{color:var(--text-secondary);flex-shrink:0}.mobile-menu-link-button:hover svg{color:var(--primary-color)}.mobile-menu-contact-tab{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.mobile-menu-user{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-top:1px solid var(--border-color);background:#f8f9fa}.mobile-menu-user-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.mobile-menu-user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.mobile-menu-user-details{flex:1;min-width:0}.mobile-menu-user-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.mobile-menu-user-email{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-menu-user-menu{background:none;border:none;padding:8px;cursor:pointer;color:var(--text-secondary);font-size:20px;line-height:1;transition:all .2s ease;border-radius:4px}.mobile-menu-user-menu:hover{background:#e5e5ea;color:var(--text-primary)}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border-color);box-shadow:0 -2px 8px #0000000a;z-index:1000;padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom))}.bottom-nav{display:flex;justify-content:space-around;align-items:center;gap:4px}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 6px;text-decoration:none;color:var(--text-secondary);transition:all .2s ease;flex:1;min-width:0;border-radius:8px}.bottom-nav-item:hover{background:#f2f2f7}.bottom-nav-item.active{color:var(--primary-color)}.bottom-nav-item.active svg{color:var(--primary-color)}.bottom-nav-item svg{flex-shrink:0;transition:all .2s ease}.bottom-nav-label{font-size:11px;font-weight:500;white-space:nowrap;text-align:center;line-height:1.2;max-width:100%}@media(max-width:768px){.hamburger-menu-btn{display:flex;align-items:center;justify-content:center}.mobile-page-title{display:block}.bottom-nav{display:flex}.top-nav-links,.top-nav-actions{display:none!important}.app-footer{display:none}.top-nav-content{padding:0 16px;height:48px;min-height:48px;gap:12px;position:relative}.main-content-web{padding:16px 16px 80px!important}.booking-page{padding:16px 0!important}.booking-form-layout{padding:0;width:100%;max-width:100%;margin:0 auto}.stats-grid,.home-articles-grid{grid-template-columns:1fr!important}.doctor-card{width:100%}.booking-row{grid-template-columns:1fr!important;gap:16px;width:100%;margin:0 auto;padding:0}.appointments-calendar-container{flex-direction:column!important}.time-slots-grid{grid-template-columns:1fr!important}.booking-time-slots{gap:8px}.booking-calendar-day,.inline-calendar-day{font-size:13px}.modal-overlay{padding:0}.modal-content{max-width:100%;max-height:100vh;border-radius:0;margin:0}.confirmation-modal-overlay{padding:0}.confirmation-modal{max-width:100%;border-radius:0;margin:0}.section-title{font-size:20px;font-weight:700;margin-bottom:16px;color:var(--text-primary)}.section-description{font-size:14px;line-height:1.5;margin-bottom:16px}.consultations-summary{background:transparent!important;border:none!important;border-radius:0!important;box-shadow:none!important;padding:0;cursor:pointer;transition:all .2s ease}.consultations-summary:hover{box-shadow:none!important}.consultations-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0}.consultations-label{font-size:16px;font-weight:500;color:var(--text-primary)}.consultations-value{font-size:16px;font-weight:700;color:var(--text-primary)}.consultations-divider{height:1px;background:var(--border-color);margin:0}.btn-with-icon{width:100%;padding:16px 20px;font-size:16px;gap:12px}.home-article-card{width:100%;margin-bottom:0}.doctors-search-container{display:flex;gap:8px;margin-bottom:16px;padding:0 16px}.doctors-search-box{flex:1;position:relative;display:flex;align-items:center}.doctors-search-icon{position:absolute;left:16px;color:var(--text-secondary);pointer-events:none;z-index:1}.doctors-search-input{width:100%;padding:14px 16px 14px 48px;border:none;border-radius:16px;font-size:16px;background:#fff;box-shadow:0 2px 8px #0000000f;transition:all .2s ease;font-family:inherit}.doctors-search-input:focus{outline:none;box-shadow:0 4px 12px #5b5fc726}.doctors-search-input::placeholder{color:#8e8e93}.doctors-filter-btn{width:48px;height:48px;border:none;border-radius:12px;background:#fff;box-shadow:0 2px 8px #0000000f;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-secondary);flex-shrink:0}.doctors-filter-btn:hover{background:#f2f2f7;color:var(--text-primary)}.doctors-filter-btn:active{transform:scale(.95)}.doctors-filter-btn.active{background:var(--primary-color);color:#fff}.doctors-filter-btn.has-filters{position:relative}.filter-badge-count{position:absolute;top:-4px;right:-4px;background:#ff3b30;color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid white}.specialty-filter-container{display:none!important}.selected-filters-container{margin-bottom:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.selected-filters-container::-webkit-scrollbar{display:none}.selected-filters-scroll{display:flex;gap:8px;padding-bottom:4px}.selected-filter-badge{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--primary-color);color:#fff;border-radius:20px;font-size:14px;font-weight:500;white-space:nowrap;flex-shrink:0}.selected-filter-remove{background:#fff3;border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#fff;padding:0;flex-shrink:0}.selected-filter-remove:hover{background:#ffffff4d}.selected-filter-remove:active{transform:scale(.9)}.filter-menu-overlay{position:fixed;inset:0;background:#00000080;z-index:10000;display:flex;align-items:flex-end;animation:fadeIn .2s ease-out}@media(min-width:769px){.filter-menu-overlay{display:none!important}}.filter-menu{background:#fff;border-radius:24px 24px 0 0;width:100%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;box-shadow:0 -4px 20px #00000026}.filter-menu-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color)}.filter-menu-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em}.filter-menu-close{background:none;border:none;padding:8px;cursor:pointer;color:var(--text-secondary);border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.filter-menu-close:hover{background:#f2f2f7;color:var(--text-primary)}.filter-menu-content{flex:1;overflow-y:auto;padding:16px}.filter-menu-actions{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.filter-clear-btn{background:none;border:none;color:var(--primary-color);font-size:15px;font-weight:500;cursor:pointer;padding:8px 12px;border-radius:8px;transition:all .2s ease}.filter-clear-btn:hover{background:#f2f2f7}.filter-menu-list{display:flex;flex-direction:column;gap:8px}.filter-menu-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left;width:100%;font-size:15px;font-weight:500;color:var(--text-primary)}.filter-menu-item:hover{background:#f2f2f7;border-color:var(--primary-color)}.filter-menu-item.selected{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.filter-menu-item-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#f2f2f7;color:var(--text-secondary);flex-shrink:0}.filter-menu-item.selected .filter-menu-item-icon{background:#fff3;color:#fff}.filter-menu-item-text{flex:1;text-align:left}.filter-menu-item-check{width:24px;height:24px;border-radius:50%;background:#fff;color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.doctor-card{padding:16px;margin-bottom:12px;min-height:72px}.doctor-photo{width:56px;height:56px}.doctor-name{font-size:16px;margin-bottom:4px}.doctor-experience{font-size:14px}.specialty-group{margin-bottom:24px}.specialty-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.specialty-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.specialty-title{font-size:18px;font-weight:600;color:var(--text-primary);flex:1}.specialty-count{font-size:14px;color:var(--text-secondary);background:#f2f2f7;padding:4px 8px;border-radius:12px}.section{margin-bottom:24px}.btn{min-height:44px;font-size:16px}.form-input,.form-textarea{font-size:16px;padding:14px 16px}.form-group{min-width:0;overflow:hidden}.form-input-date,.form-input[type=date]{width:100%;max-width:100%;min-width:0;box-sizing:border-box;overflow:hidden;padding:12px 16px;font-size:16px;border-radius:12px;background:#fff;border:1px solid var(--border-color);font-family:inherit;letter-spacing:-.01em;-webkit-appearance:none;appearance:none}.appointments-page .page-content{padding:8px}.appointments-desktop-layout{display:flex;flex-direction:column;gap:16px}.appointments-left-column,.appointments-right-column{width:100%}gap: 12px}.appointments-status-table{width:100%;background:transparent;border-radius:0;padding:0;box-shadow:none;margin-bottom:8px}.status-table-header{margin-bottom:6px;padding:0}.status-table-header h4{font-size:14px;margin-bottom:0}.status-table-body.status-table-horizontal{display:grid!important;grid-template-columns:1fr 1fr;gap:4px;flex-wrap:unset;margin:0;padding:0}.status-table-row{padding:6px 8px;border-radius:8px;min-height:auto;display:flex;flex-direction:row;justify-content:space-between;align-items:center;transition:all .2s ease;flex:1;min-width:0}.status-table-label{display:flex;align-items:center;gap:5px;margin-bottom:0;font-size:12px}.status-table-count{font-size:13px;font-weight:700;text-align:right;margin-left:6px}.appointments-calendar-container{width:100%;padding:12px 0;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000f}.appointments-calendar-container .booking-calendar{padding:0 8px}.appointments-calendar-container .booking-calendar-header{margin-bottom:12px;padding:0 4px;width:100%;position:relative;display:flex;justify-content:space-between;align-items:center;box-sizing:border-box}.appointments-calendar-container .calendar-current-month{flex:1;text-align:center}.appointments-calendar-container .calendar-nav-btn{flex-shrink:0;position:absolute;z-index:1}.appointments-calendar-container .calendar-nav-btn:first-of-type{left:4px}.appointments-calendar-container .calendar-nav-btn:last-of-type{right:4px}.calendar-current-month{font-size:15px;font-weight:600}.calendar-nav-btn{width:32px;height:32px;padding:6px}.appointments-calendar-container .booking-calendar-grid{gap:4px;padding:0 4px}.booking-calendar-day{font-size:13px;min-height:36px;font-weight:500}.booking-calendar-weekday{font-size:10px;padding:6px 0;font-weight:600}.calendar-day-badge{position:absolute;top:2px;right:2px;color:#fff;border-radius:50%;font-size:9px;line-height:1.2;padding:2px 4px;min-width:16px;height:16px;text-align:center;font-weight:700;box-shadow:0 1px 3px #0000004d;z-index:1;display:flex;align-items:center;justify-content:center}.status-table-row{padding:12px}.status-table-label{font-size:14px}.status-table-count{font-size:18px}.appointments-tabs{margin-bottom:16px;padding:4px}.appointments-tab{padding:10px 16px;font-size:14px}.appointment-item-card{flex-direction:column;gap:12px;padding:16px}.appointment-item-info{width:100%}.appointment-item-actions{width:100%;justify-content:flex-end;margin-top:8px}.appointment-action-btn{width:40px;height:40px}.booking-calendar{width:100%}.booking-calendar-grid{gap:4px}.booking-calendar-day{font-size:13px;min-height:36px;position:relative}.inline-calendar{padding:12px 8px}.inline-calendar-grid{gap:4px}.inline-calendar-day{font-size:13px;min-height:36px;position:relative}.booking-page{padding:16px 0!important;max-width:100%}.booking-form-layout{padding:0 8px}.booking-doctor-header{padding:16px;flex-direction:column;text-align:center;gap:12px;box-shadow:none}.doctor-avatar-large{width:70px;height:70px;font-size:32px;margin:0 auto}.booking-doctor-name{font-size:18px;text-align:center}.booking-doctor-specialty{text-align:center}.booking-section{background:transparent!important;border:none!important;border-radius:0!important;box-shadow:none!important;padding:0 8px;width:100%;display:flex;flex-direction:column;align-items:stretch}.booking-section-title{font-size:14px;margin-bottom:12px;padding:0;background:transparent!important;width:100%;display:flex;align-items:center;justify-content:center;gap:8px}.booking-calendar{width:100%;max-width:100%;margin:0 auto;padding:0}.booking-calendar-header{padding:0 4px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;width:100%;position:relative;box-sizing:border-box}.calendar-current-month{font-size:15px;font-weight:600;text-align:center;flex:1}.calendar-nav-btn{width:32px;height:32px;padding:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:absolute;z-index:1}.calendar-nav-btn:first-of-type{left:4px}.calendar-nav-btn:last-of-type{right:4px}.booking-calendar-grid{width:100%;padding:0 4px;margin:0 auto;box-sizing:border-box}.booking-time-slots{gap:8px;width:100%;max-width:100%;margin:0 auto;display:flex;flex-direction:column;align-items:stretch}.booking-time-slot{padding:14px 16px;font-size:15px;width:100%;margin:0;display:flex;align-items:center;justify-content:flex-start;text-align:left}.booking-notes{background:transparent!important;border-radius:0!important;box-shadow:none!important;padding:0}.booking-notes-textarea{min-height:120px;font-size:16px}.booking-files{background:transparent!important;border-radius:0!important;box-shadow:none!important;padding:0}.file-upload-button{width:100%;justify-content:center;padding:14px 20px;font-size:15px}.uploaded-file-item{padding:12px}.booking-checkbox{background:transparent!important;border-radius:0!important;box-shadow:none!important;padding:0}.booking-submit-btn{padding:16px 24px;font-size:16px;min-height:52px}.profile-info-card{padding:12px}.profile-info-row{padding:14px 0;gap:12px}.profile-info-icon{width:36px;height:36px;flex-shrink:0}.profile-info-label{font-size:12px;margin-bottom:4px}.profile-info-value{font-size:15px;word-break:break-word}.search-box{margin-bottom:12px}.search-input{padding:14px 16px 14px 48px;font-size:16px}.articles-list{gap:12px}.article-card{padding:12px;gap:12px}.article-image{width:50px;height:50px;font-size:24px}.article-title{font-size:15px}.article-description{font-size:12px}.stat-card{padding:16px}.stat-label{font-size:13px}.stat-value{font-size:28px}.program-widget{background:transparent!important;border:none!important;border-radius:0!important;box-shadow:none!important;padding:0}.program-widget-header h3{font-size:16px}.program-widget-name{font-size:14px;margin-bottom:12px}.program-stats{grid-template-columns:1fr;gap:12px}.program-stat-item{padding:14px}.program-stat-value{font-size:28px}.program-dates-table{gap:10px}.program-date-row{flex-direction:column;align-items:flex-start;gap:4px}.program-date-value{text-align:left}.empty-state,.loading-state{padding:32px 20px}.tabs{gap:6px;margin-bottom:12px}.tab{padding:10px 14px;font-size:13px}.doctor-card,.article-card,.appointment-item-card,.consultation-card{min-height:60px;cursor:pointer}.calendar-controls{padding:0 8px;margin-bottom:16px}.month-navigation{gap:6px}.nav-btn{width:44px;height:44px;padding:8px}.calendar-nav-btn{width:40px;height:40px}.time-slot{padding:14px 12px;font-size:15px;min-height:48px}.modal-header{padding:20px}.modal-header h2{font-size:20px}.modal-body{padding:20px}.modal-footer{padding:16px 20px;flex-direction:column;gap:10px}.modal-footer .btn{width:100%}.confirmation-modal-header{padding:24px 20px 20px}.confirmation-title{font-size:20px}.confirmation-modal-content{padding:20px}.confirmation-details{padding:16px}.confirmation-detail-row{flex-direction:column;align-items:flex-start;gap:4px;padding:10px 0}.confirmation-value{text-align:left;max-width:100%}.confirmation-modal-footer{padding:16px 20px 20px}.confirmation-buttons{flex-direction:column}.confirmation-btn{width:100%;padding:14px 20px}.future-appointments-widget{padding:16px;margin-bottom:16px}.future-appointments-title{font-size:15px}.future-appointment-badge{padding:6px 10px;font-size:12px}.future-appointment-count{font-size:13px}.login-page{padding:16px}.login-form{padding:24px 20px;min-width:0;overflow:hidden}.login-form h2{font-size:22px}.form-group{margin-bottom:16px}.doctor-detail-card{padding:20px}.doctor-detail-photo{width:100px;height:100px;font-size:50px}.doctor-detail-name{font-size:18px}.doctor-detail-specialty{font-size:15px}.doctor-info-section{padding-top:12px;margin-bottom:16px}.info-section-title{font-size:13px}.info-section-text{font-size:14px}@media(min-width:769px){.hamburger-menu-btn,.mobile-page-title,.bottom-nav{display:none!important}.top-nav-links,.top-nav-actions{display:flex!important}.app-footer{display:block}.main-content-web{padding-bottom:32px!important}.specialty-filter-container{display:block!important;margin-bottom:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.specialty-filter-container::-webkit-scrollbar{display:none}.specialty-filter-badges{display:flex;gap:8px;padding-bottom:4px}.specialty-filter-badge{padding:10px 16px;border:1px solid var(--border-color);border-radius:20px;background:#fff;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.specialty-filter-badge:hover{background:#f2f2f7}.specialty-filter-badge.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.filter-menu-overlay,.selected-filters-container,.doctors-filter-btn{display:none!important}.doctors-search-container{display:flex;gap:12px;margin-bottom:24px;padding:0 32px;max-width:1400px;margin-left:auto;margin-right:auto}.doctors-search-box{flex:1;position:relative;display:flex;align-items:center;max-width:600px}.doctors-search-icon{position:absolute;left:16px;color:var(--text-secondary);pointer-events:none;z-index:1}.doctors-search-input{width:100%;padding:14px 16px 14px 48px;border:none;border-radius:16px;font-size:16px;background:#fff;box-shadow:0 2px 8px #0000000f;transition:all .2s ease;font-family:inherit}.doctors-search-input:focus{outline:none;box-shadow:0 4px 12px #5b5fc726}.doctors-search-input::placeholder{color:#8e8e93}.filter-menu-overlay{display:none!important}.program-widget{background:#fff;border:1px solid var(--border-color);border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f}.program-widget-header{margin-bottom:16px}.program-widget-name{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.program-widget-content{display:flex;flex-direction:column;gap:20px}.program-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}.program-progress-container{margin-top:4px}.consultations-summary{background:#fff!important;border:1px solid var(--border-color)!important;border-radius:16px!important;box-shadow:0 2px 8px #0000000f!important;padding:20px 24px!important}.consultations-summary:hover{box-shadow:0 4px 12px #5b5fc726!important;transform:translateY(-2px);border-color:var(--primary-color)!important}.consultations-value{font-size:20px;font-weight:700;color:var(--primary-color)}.appointments-page .page-content{display:flex!important;flex-direction:row!important;gap:24px;align-items:flex-start}.appointments-desktop-layout{display:flex;gap:24px;align-items:flex-start}.appointments-left-column{flex:0 0 35%;display:flex;flex-direction:column;gap:24px}.appointments-right-column{flex:0 0 65%;display:flex;flex-direction:column;gap:16px}.appointments-left-column .appointments-calendar-container{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f;margin-bottom:0;max-width:none;width:100%;box-sizing:border-box}.appointments-calendar-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px;padding:0}.appointments-left-column .appointments-calendar-container .booking-calendar{width:100%}.appointments-left-column .appointments-status-table{background:#fff;border-radius:20px;padding:24px;box-shadow:0 2px 12px #0000000f;margin-bottom:0;flex:none;width:100%;box-sizing:border-box}.appointments-left-column .appointments-status-table .status-table-body{display:flex;flex-direction:column;gap:12px}.appointments-left-column .appointments-status-table .status-table-row{padding:12px 16px}.appointments-right-column .active-filter-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:0}.appointments-right-column .appointments-list-container{flex:1}.appointments-status-table{flex:0 0 300px;margin-bottom:0!important}.status-table-body.status-table-horizontal{display:flex!important;flex-direction:column!important;gap:10px}.status-table-row{flex-direction:row!important;justify-content:space-between!important;align-items:center!important;min-height:auto!important;padding:8px 12px}.status-table-label{margin-bottom:0!important;font-size:13px}.status-table-count{text-align:right!important;font-size:14px!important}.appointments-calendar-container{flex:1;min-width:0}.calendar-day-badge{top:0!important;right:0!important;font-size:8px!important}}.symptom-checker-page{max-width:800px;margin:0 auto;padding:24px}.symptom-checker-header{display:flex;align-items:center;gap:16px;margin-bottom:32px;position:relative}.symptom-checker-header h1{margin:0;font-size:28px;font-weight:600}.btn-back{display:flex;align-items:center;gap:8px;padding:8px 16px;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;font-size:15px;border-radius:8px;transition:all .2s ease}.btn-back:hover{background:#f5f5f5;color:var(--text-primary)}.symptom-checker-content{background:#fff;border-radius:16px;padding:32px;box-shadow:0 2px 8px #0000000f}.symptom-step{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.symptom-step h2{margin:0 0 8px;font-size:24px;font-weight:600;color:var(--text-primary)}.step-description{margin:0 0 24px;color:var(--text-secondary);font-size:15px;line-height:1.5}.symptom-options{display:flex;flex-direction:column;gap:12px}.symptom-option{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border:2px solid var(--border-color);border-radius:12px;background:#fff;cursor:pointer;transition:all .2s ease;font-size:16px;text-align:left}.symptom-option:hover{border-color:var(--primary-color);background:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #5b5fc71a}.symptom-option.btn-primary{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.symptom-option.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.symptom-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}.symptom-option-btn{padding:16px;border:1px solid #E5E5EA;border-radius:12px;background:#fff;color:var(--text-primary);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:48px;display:flex;align-items:center;justify-content:center;text-align:center;word-wrap:break-word;white-space:normal}.symptom-option-btn:hover{background:#f2f2f7;border-color:var(--primary-color)}.symptom-option-btn.selected{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.symptom-options-list{display:flex;flex-direction:column;gap:0;margin-bottom:24px}.symptom-radio-option,.symptom-checkbox-option{display:flex;align-items:flex-start;gap:12px;padding:16px;border:none;border-bottom:1px solid #E5E5EA;background:#fff;cursor:pointer;transition:background .2s ease;text-align:left}.symptom-radio-option:last-child,.symptom-checkbox-option:last-child{border-bottom:none}.symptom-radio-option:hover,.symptom-checkbox-option:hover{background:#f2f2f7}.symptom-radio-option input[type=radio],.symptom-checkbox-option input[type=checkbox]{width:20px;height:20px;margin:2px 0 0;cursor:pointer;flex-shrink:0;accent-color:var(--primary-color)}.symptom-radio-text,.symptom-checkbox-text{flex:1;font-size:15px;line-height:1.5;color:var(--text-primary);word-wrap:break-word;white-space:normal;text-align:left}.symptom-radio-option.selected,.symptom-checkbox-option.selected{background:#f2f2f7}.results-list{margin:24px 0}.result-item{background:#f9f9f9;border-radius:12px;padding:20px;margin-bottom:20px;border:1px solid var(--border-color)}.result-item h3{margin:0 0 16px;font-size:20px;font-weight:600;color:var(--text-primary)}.error-alert{padding:12px 16px;background-color:#fee;color:#c33;border-radius:8px;border-left:4px solid #c33;margin-bottom:20px}@media(max-width:768px){.symptom-checker-page{padding:16px}.symptom-checker-content{padding:20px;border-radius:12px}.symptom-checker-header h1{font-size:22px}.symptom-step h2{font-size:20px}.symptom-option{padding:14px 16px;font-size:15px}.symptom-options-grid{grid-template-columns:1fr;gap:10px}.symptom-option-btn{padding:14px;font-size:14px;min-height:44px;text-align:center!important;justify-content:center!important}.symptom-radio-option,.symptom-checkbox-option{padding:14px}.symptom-radio-text,.symptom-checkbox-text{font-size:14px}.symptom-checker-back-btn{display:none}.symptom-step .symptom-summary-item{flex-direction:column;align-items:flex-start!important;text-align:left!important}.symptom-step .symptom-summary-item span:first-child{margin-bottom:4px}.symptom-step .symptom-summary-item span:last-child{text-align:left!important;max-width:100%!important}}
