@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.navbar{background:var(--bg-surface);box-shadow:var(--shadow-sm);border-bottom:1px solid var(--border-color);z-index:100;transition:all .2s;position:sticky;top:0}.navbar-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1.2rem 2rem;display:flex}.logo{color:var(--primary);cursor:pointer;letter-spacing:-.5px;margin:0;font-size:1.8rem;font-weight:700;transition:color .2s}.logo:hover{color:var(--primary-dark)}.nav-links{flex:1;gap:2.5rem;margin-left:3rem;display:flex}.nav-links span{cursor:pointer;color:var(--text-main);font-size:1rem;font-weight:500;transition:color .2s;position:relative}.nav-links span:hover{color:var(--primary)}.nav-actions{align-items:center;gap:1rem;display:flex}.login-btn{color:var(--primary);border:1px solid var(--primary);cursor:pointer;background-color:#0000;border-radius:6px;padding:.6rem 1.8rem;font-family:inherit;font-size:1rem;font-weight:500;transition:all .2s}.login-btn:hover{background-color:var(--bg-alt)}.logout-btn{color:#b91c1c;cursor:pointer;background-color:#fff;border:1px solid #fca5a5;border-radius:6px;padding:.6rem 1.8rem;font-family:inherit;font-size:1rem;font-weight:500;transition:all .2s}.logout-btn:hover{background-color:#fef2f2}@media (width<=768px){.navbar-container{padding:1rem}.nav-links{display:none}.nav-actions{gap:.5rem}.login-btn,.primary-btn,.logout-btn{padding:.5rem 1rem;font-size:.9rem}}.footer{color:#fff;background-color:#1a1a1a;margin-top:3rem;padding:3rem 2rem 1rem}.footer-container{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1200px;margin:0 auto 2rem;display:grid}.footer-section h3{color:#1faf8b;margin-bottom:1rem;font-size:1.5rem}.footer-section h4{color:#fff;margin-bottom:1rem;font-size:1.1rem}.footer-section p{color:#ccc;margin:.5rem 0;line-height:1.6}.footer-section ul{margin:0;padding:0;list-style:none}.footer-section ul li{color:#ccc;cursor:pointer;margin:.5rem 0;transition:color .3s}.footer-section ul li:hover{color:#1faf8b}.footer-bottom{text-align:center;color:#999;border-top:1px solid #333;padding-top:2rem}.footer-bottom p{margin:0}@media (width<=768px){.footer{padding:2rem 1rem 1rem}.footer-container{grid-template-columns:1fr;gap:1.5rem}.footer-section h3{font-size:1.2rem}.footer-section h4{font-size:1rem}}.home{background:var(--bg-main);flex-direction:column;flex:1;width:100%;display:flex}.hero{justify-content:space-between;align-items:center;gap:60px;min-height:85vh;padding:80px 10%;display:flex}.hero-left{max-width:560px}.tag{background:var(--bg-alt);color:var(--primary);border:1px solid var(--border-color);border-radius:4px;align-items:center;margin-bottom:24px;padding:8px 16px;font-size:14px;font-weight:600;display:inline-flex}.hero-title{color:var(--text-main);margin:0 0 24px;font-size:56px;font-weight:700;line-height:1.15}.desc{color:var(--text-muted);margin:0 0 40px;font-size:18px;font-weight:400;line-height:1.6}.buttons{align-items:center;gap:16px;display:flex}.primary-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:16px 32px;font-family:inherit;font-size:16px;font-weight:500;transition:background .2s}.primary-btn:hover{background:var(--primary-dark)}.outline-btn{border:1px solid var(--primary);color:var(--primary);cursor:pointer;background:0 0;border-radius:6px;padding:16px 32px;font-family:inherit;font-size:16px;font-weight:500;transition:background .2s}.hero-right{flex:1;justify-content:center;align-items:center;display:flex}.hero-right img{width:100%;max-width:500px;height:auto;box-shadow:var(--shadow-md);object-fit:cover;border:4px solid var(--bg-surface);border-radius:12px}@media (width<=1024px){.hero{gap:40px;padding:60px 5%}.hero-title{font-size:48px}}@media (width<=768px){.hero{text-align:center;flex-direction:column;padding:40px 5% 80px}.hero-left{flex-direction:column;align-items:center;max-width:100%;display:flex}.hero-title{font-size:40px}.buttons{flex-wrap:wrap;justify-content:center;width:100%}.hero-right{width:100%;margin-top:40px}}.auth-page,.register-page{background:var(--bg-main);justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:3rem 1rem;display:flex}.auth-card,.register-card{background:var(--bg-surface);border:1px solid var(--border-color);width:min(100%,460px);box-shadow:var(--shadow-sm);border-radius:8px;padding:2.5rem}.auth-tag,.register-tag{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.auth-card h2,.register-card h2{color:var(--text-main);margin:0 0 .5rem;font-size:2rem;font-weight:700}.auth-text,.register-card p{color:var(--text-muted);margin:0 0 2rem;font-size:1rem;line-height:1.5}.auth-form,.register-form{gap:1.2rem;display:grid}.auth-form label,.register-form label{color:var(--text-main);gap:.5rem;font-weight:500;display:grid}.auth-form span,.register-form span{font-size:.95rem}.auth-form input,.auth-form select,.register-form input,.register-form select{border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-main);border-radius:4px;outline:none;padding:.8rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.auth-form input:focus,.auth-form select:focus,.register-form input:focus,.register-form select:focus{border-color:var(--primary)}.auth-error,.register-error{color:#b91c1c;background:#fef2f2;border:1px solid #fca5a5;border-radius:4px;margin:0;padding:.8rem 1rem;font-size:.95rem}.auth-primary,.auth-secondary,.register-actions button{cursor:pointer;border:1px solid #0000;border-radius:4px;padding:.9rem 1rem;font-family:inherit;font-size:1rem;font-weight:600;transition:background .2s,border-color .2s}.auth-primary,.register-primary{background:var(--primary);color:#fff}.auth-primary:hover,.register-primary:hover{background:var(--primary-dark)}.auth-secondary,.register-secondary{color:var(--primary);border-color:var(--primary);background:0 0}.auth-secondary:hover,.register-secondary:hover{background:var(--bg-alt)}.register-actions{gap:1rem;margin-top:1rem;display:grid}@media (width<=640px){.auth-card,.register-card{padding:1.5rem}}.patient-page{background:var(--bg-main);min-height:calc(100vh - 80px);padding:3rem 1rem}.patient-hero{background:var(--bg-surface);border:1px solid var(--border-color);max-width:980px;box-shadow:var(--shadow-sm);border-radius:8px;margin:0 auto 2rem;padding:2.5rem}.patient-tag{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.patient-hero h2{color:var(--text-main);margin:0 0 .5rem;font-size:clamp(2rem,3vw,2.5rem);font-weight:700}.patient-hero p{color:var(--text-muted);margin:0;font-size:1.1rem;line-height:1.6}.patient-actions{flex-wrap:wrap;gap:1rem;margin-top:1.5rem;display:flex}.patient-actions button,.patient-main-btn{cursor:pointer;border:none;border-radius:4px;padding:.9rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.patient-actions button:first-child,.patient-main-btn{background:var(--primary);color:#fff}.patient-actions button:first-child:hover,.patient-main-btn:hover{background:var(--primary-dark)}.patient-actions button:last-child{color:var(--primary);border:1px solid var(--primary);background:0 0}.patient-actions button:last-child:hover{background:var(--bg-alt)}.patient-stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:1.5rem;max-width:980px;margin:0 auto;display:grid}.patient-stat-card,.patient-panel{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px}.patient-stat-card{padding:1.5rem}.patient-stat-card span{color:var(--text-muted);margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:block}.patient-stat-card strong{color:var(--text-main);font-size:2rem;font-weight:700}.patient-grid{grid-template-columns:1fr .9fr;gap:1.5rem;max-width:980px;margin:2rem auto 0;display:grid}.patient-panel{padding:1.5rem}.patient-panel h3{color:var(--text-main);margin:0 0 1.2rem;font-size:1.2rem;font-weight:600}.patient-panel p,.patient-panel ul{color:var(--text-muted);margin:0;line-height:1.6}.patient-panel ul{gap:.8rem;padding-left:1.2rem;display:grid}@media (width<=900px){.patient-stats,.patient-grid{grid-template-columns:1fr 1fr}}@media (width<=640px){.patient-stats,.patient-grid{grid-template-columns:1fr}.patient-hero{padding:1.5rem}}.doctor-card{background:var(--bg-surface);border:1px solid var(--border-color);width:100%;box-shadow:var(--shadow-sm);border-radius:8px;flex-direction:column;transition:transform .2s,box-shadow .2s;display:flex;overflow:hidden}.doctor-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.doctor-card-main{gap:1.2rem;padding:1.5rem;display:flex}.doctor-avatar-wrapper{flex-shrink:0}.doctor-avatar{object-fit:cover;background:var(--bg-alt);border:1px solid var(--border-color);border-radius:8px;width:90px;height:90px}.doctor-avatar-fallback{background:var(--bg-alt);color:var(--primary);border:1px solid var(--border-color);border-radius:8px;justify-content:center;align-items:center;width:90px;height:90px;font-size:2rem;font-weight:700;display:flex}.doctor-info{flex-direction:column;flex:1;justify-content:center;min-width:0;display:flex}.doctor-name{color:var(--text-main);margin:0 0 .2rem;font-size:1.25rem;font-weight:700;line-height:1.2}.doctor-specialty{color:var(--primary);margin:0 0 .5rem;font-size:.95rem;font-weight:500}.doctor-meta-row{color:var(--text-muted);flex-direction:column;gap:.2rem;margin-bottom:.8rem;font-size:.9rem;display:flex}.doctor-meta-tags{flex-wrap:wrap;gap:.5rem;display:flex}.meta-tag{background:var(--bg-main);border:1px solid var(--border-color);color:var(--text-muted);white-space:nowrap;border-radius:4px;align-items:center;padding:4px 8px;font-size:.85rem;display:inline-flex}.slot-tag{color:var(--primary);background:#f0fdf4;border-color:#bbf7d0;font-weight:600}.doctor-card-footer{background:var(--bg-main);border-top:1px solid var(--border-color);flex-direction:column;gap:1rem;padding:1.2rem 1.5rem;display:flex}.doctor-fee-row{justify-content:space-between;align-items:center;display:flex}.doctor-fee-row span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;font-weight:500}.doctor-fee-row strong{color:var(--text-main);font-size:1.4rem;font-weight:700;line-height:1}.doctor-actions{gap:.8rem;width:100%;display:flex}.doctor-button{cursor:pointer;text-align:center;border-radius:4px;flex:1;padding:.8rem .5rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .2s}.doctor-button-outline{background:var(--bg-surface);color:var(--text-main);border:1px solid var(--border-color)}.doctor-button-outline:hover{background:var(--bg-alt);border-color:var(--text-muted)}.doctor-button-solid{background:var(--primary);color:#fff;border:1px solid var(--primary)}.doctor-button-solid:hover{background:var(--primary-dark);border-color:var(--primary-dark)}@media (width<=480px){.doctor-actions{flex-direction:column}}.doctor-hero{text-align:center;max-width:800px;margin:0 auto 3rem;padding:0 20px}.doctor-hero-tag{background:var(--bg-alt);color:var(--primary);border:1px solid var(--border-color);border-radius:4px;margin-bottom:1rem;padding:6px 12px;font-size:.9rem;font-weight:600;display:inline-block}.doctor-hero h1{letter-spacing:-.5px;color:var(--text-main);margin-bottom:15px;font-size:clamp(2.2rem,4vw,3rem);font-weight:700;line-height:1.2}.doctor-hero-text{color:var(--text-muted);max-width:600px;margin:0 auto;font-size:1.1rem}.doctor-search{background:var(--bg-surface);border:1px solid var(--border-color);max-width:760px;box-shadow:var(--shadow-sm);border-radius:8px;gap:12px;margin:2rem auto;padding:.8rem;display:flex}.doctor-search input{border:1px solid var(--border-color);background:var(--bg-main);border-radius:4px;outline:none;flex:1;padding:.8rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.doctor-search input:focus{border-color:var(--primary)}.clear-button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:4px;padding:.8rem 1.5rem;font-family:inherit;font-weight:500;transition:background .2s}.clear-button:hover{background:var(--primary-dark)}.doctor-layout{grid-template-columns:260px minmax(0,1fr);align-items:start;gap:2rem;display:grid}.doctor-sidebar{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px;padding:1.5rem;position:sticky;top:100px}.filter-group+.filter-group{margin-top:1.8rem}.filter-group h3{color:var(--text-main);margin:0 0 1rem;font-size:1rem;font-weight:600}.filter-list{flex-direction:column;gap:.8rem;display:flex}.filter-item{color:var(--text-muted);cursor:pointer;align-items:center;gap:.8rem;font-size:.95rem;display:flex}.filter-item:hover{color:var(--text-main)}.filter-item input{accent-color:var(--primary);cursor:pointer;width:16px;height:16px}.doctor-results{min-width:0}.doctor-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px;display:grid}.empty-state{background:var(--bg-surface);border:1px solid var(--border-color);text-align:center;border-radius:8px;margin-top:2rem;padding:3rem 2rem}.empty-state h3{color:var(--text-main);margin:0 0 .5rem;font-size:1.2rem}.empty-state p{color:var(--text-muted);margin:0}@media (width<=1100px){.doctor-layout{grid-template-columns:1fr}.doctor-sidebar{margin-bottom:2rem;position:static}}@media (width<=768px){.doctor-page{padding:2rem 1rem}.doctor-search{flex-direction:column}.doctor-grid{grid-template-columns:1fr}}.about-page{background:var(--bg-main);min-height:calc(100vh - 80px);padding:4rem 3rem}.about-hero{text-align:center;max-width:900px;margin:0 auto 3rem}.about-kicker{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.9rem;font-weight:600}.about-hero h1{color:var(--text-main);margin:1rem 0 1.5rem;font-size:clamp(2.5rem,4vw,3.5rem);font-weight:800;line-height:1.2}.about-hero p{color:var(--text-muted);max-width:700px;margin:0 auto;font-size:1.1rem;line-height:1.7}.about-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:2rem;max-width:1080px;margin:0 auto;display:grid}.about-card{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px;padding:2rem}.about-card h2{color:var(--text-main);margin:0 0 1rem;font-size:1.5rem;font-weight:700}.about-card p,.about-card li{color:var(--text-muted);margin:0;font-size:1.05rem;line-height:1.7}.about-card ul{gap:.8rem;margin:1rem 0 0;padding-left:1.2rem;display:grid}.about-highlights{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem;max-width:1080px;margin:2rem auto 0;display:grid}.highlight-card{background:var(--primary);color:#fff;text-align:center;border-radius:8px;padding:2rem}.highlight-value{margin:0;font-size:2.5rem;font-weight:800}.highlight-card h3{margin:.5rem 0;font-size:1.2rem;font-weight:600}.highlight-card p{color:#fffc;margin:0;line-height:1.5}@media (width<=900px){.about-page{padding:2rem 1.5rem}.about-grid,.about-highlights{grid-template-columns:1fr}}.details-page{background:var(--bg-main);min-height:100vh;padding:3rem}.back-link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:2rem;padding:8px 0;font-size:1rem;font-weight:500;display:inline-flex}.back-link:hover{color:var(--primary)}.details-layout{grid-template-columns:minmax(0,1fr) 350px;align-items:start;gap:2rem;display:grid}.left-column,.right-column{gap:1.5rem;display:grid}.simple-card{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px;padding:2rem}.profile-top{align-items:flex-start;gap:1.5rem;display:flex}.doctor-photo{background:var(--bg-alt);width:120px;height:120px;color:var(--primary);border:1px solid var(--border-color);border-radius:8px;flex-shrink:0;place-items:center;font-size:2.5rem;font-weight:700;display:grid}.profile-text h1{color:var(--text-main);letter-spacing:-.5px;margin:0;font-size:2rem;font-weight:700}.specialty-text{color:var(--primary);margin:.5rem 0;font-size:1.1rem;font-weight:500}.meta-text,.location-text{color:var(--text-muted);margin:.5rem 0 0;font-size:.95rem}.tag-list{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.tag-pill{background:var(--bg-alt);color:var(--text-main);border:1px solid var(--border-color);border-radius:4px;padding:4px 10px;font-size:.85rem;font-weight:500}.simple-card h2{color:var(--text-main);margin:0 0 1rem;font-size:1.5rem;font-weight:600}.simple-card h3{color:var(--text-main);margin:0 0 1rem;font-size:1.2rem;font-weight:600}.simple-card p{color:var(--text-muted);margin:0;font-size:1rem;line-height:1.6}.education-list{color:var(--text-muted);gap:.8rem;margin:0;padding-left:1.2rem;font-size:1rem;display:grid}.fee-card{text-align:center}.fee-card p{color:var(--text-muted);margin-bottom:.5rem;font-size:1rem}.fee-card h2{color:var(--primary);margin-bottom:1.5rem;font-size:2rem;font-weight:700}.info-row{color:var(--text-muted);border-bottom:1px solid var(--border-color);justify-content:space-between;gap:1rem;padding:.8rem 0;display:flex}.info-row:last-child{border-bottom:none}.info-row strong{color:var(--text-main)}.slot-list{gap:.5rem;margin-bottom:1.5rem;display:grid}.slot-item{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-main);border-radius:6px;justify-content:space-between;align-items:center;padding:.8rem 1rem;font-weight:500;display:flex}.slot-check{color:var(--primary);font-weight:700}.solid-btn,.outline-btn{cursor:pointer;border-radius:6px;padding:1rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.solid-btn{background:var(--primary);color:#fff;border:none}.solid-btn:hover{background:var(--primary-dark)}.outline-btn{color:var(--primary);border:1px solid var(--primary);background:0 0}.outline-btn:hover{background:var(--bg-alt)}.full-btn{width:100%}.not-found-card{text-align:center;max-width:480px;margin:4rem auto}.not-found-card h2{margin-bottom:1rem;font-size:1.5rem}@media (width<=1100px){.details-layout{grid-template-columns:1fr}}@media (width<=768px){.details-page{padding:2rem 1rem}.profile-top{text-align:center;flex-direction:column;align-items:center}.tag-list{justify-content:center}}.booking-page{background:var(--bg-main);justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:3rem 1rem;display:flex}.booking-card{background:var(--bg-surface);border:1px solid var(--border-color);width:min(100%,520px);box-shadow:var(--shadow-sm);border-radius:8px;padding:2.5rem}.booking-tag{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.booking-card h2{color:var(--text-main);margin:0 0 .5rem;font-size:2rem;font-weight:700}.booking-card p{color:var(--text-muted);margin:0 0 2rem;font-size:1rem;line-height:1.5}.booking-form{gap:1.2rem;display:grid}.booking-form label{color:var(--text-main);gap:.5rem;font-weight:500;display:grid}.booking-form input,.booking-form select{border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-main);border-radius:4px;outline:none;padding:.8rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.booking-form input:focus,.booking-form select:focus{border-color:var(--primary)}.booking-actions{gap:1rem;margin-top:1rem;display:grid}.booking-error{color:#b91c1c;background:#fef2f2;border:1px solid #fca5a5;border-radius:4px;margin:.8rem 0 0;padding:.8rem 1rem;font-size:.95rem;font-weight:500}.booking-primary,.booking-secondary{cursor:pointer;border:1px solid #0000;border-radius:4px;padding:.9rem 1rem;font-family:inherit;font-size:1rem;font-weight:600;transition:background .2s,border-color .2s}.booking-primary{background:var(--primary);color:#fff}.booking-primary:hover{background:var(--primary-dark)}.booking-primary:disabled{opacity:.7;cursor:not-allowed}.booking-secondary{color:var(--primary);border-color:var(--primary);background:0 0}.booking-secondary:hover{background:var(--bg-alt)}.my-appointments-page{background:var(--bg-main);min-height:calc(100vh - 80px);padding:3rem 1rem}.my-appointments-hero{background:var(--bg-surface);border:1px solid var(--border-color);max-width:980px;box-shadow:var(--shadow-sm);border-radius:8px;margin:0 auto 1.5rem;padding:2.5rem}.my-appointments-tag{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.my-appointments-hero h2{color:var(--text-main);margin:0 0 .5rem;font-size:clamp(2rem,3vw,2.5rem);font-weight:700}.my-appointments-hero p{color:var(--text-muted);margin:0;font-size:1.1rem;line-height:1.6}.my-appointments-actions{flex-wrap:wrap;gap:1rem;margin-top:1.5rem;display:flex}.my-appointments-actions button{cursor:pointer;border:none;border-radius:4px;padding:.9rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.my-appointments-actions button:first-child{background:var(--primary);color:#fff}.my-appointments-actions button:first-child:hover{background:var(--primary-dark)}.my-appointments-actions button:last-child{color:var(--primary);border:1px solid var(--primary);background:0 0}.my-appointments-actions button:last-child:hover{background:var(--bg-alt)}.my-appointments-stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:1.5rem;max-width:980px;margin:0 auto;display:grid}.my-appointments-stats article{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px;padding:1.5rem}.my-appointments-stats span{color:var(--text-muted);margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:block}.my-appointments-stats strong{color:var(--text-main);font-size:2rem;font-weight:700}.filter-row{flex-wrap:wrap;gap:.8rem;max-width:980px;margin:2rem auto 0;display:flex}.filter-row button{border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-main);cursor:pointer;border-radius:4px;padding:.7rem 1.2rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .2s}.filter-row button.active{background:var(--primary);border-color:var(--primary);color:#fff}.my-appointments-info,.my-appointments-error{max-width:980px;margin:1.5rem auto 0}.my-appointments-info{color:var(--text-main)}.my-appointments-error{color:#b91c1c;background:#fef2f2;border:1px solid #fca5a5;border-radius:4px;padding:1rem;font-weight:600}.my-appointments-list{gap:1rem;max-width:980px;margin:1.5rem auto 0;display:grid}.my-appointment-card{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px;grid-template-columns:1.5fr 1fr auto;align-items:center;gap:1rem;padding:1.5rem;display:grid}.appointment-main h3{color:var(--text-main);margin:0;font-size:1.1rem}.appointment-main p{color:var(--text-muted);margin:.4rem 0 0}.appointment-meta{color:var(--text-main);gap:.4rem;font-weight:500;display:grid}.appointment-status-col{justify-items:end;gap:.8rem;display:grid}.status-pill{border:1px solid #0000;border-radius:4px;padding:.4rem .8rem;font-size:.85rem;font-weight:600}.status-confirmed{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.status-pending{color:#854d0e;background:#fefce8;border-color:#fef08a}.status-completed{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.status-cancelled{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.appointment-status-col button,.my-appointments-empty button{color:#b91c1c;cursor:pointer;background:#fef2f2;border:1px solid #fca5a5;border-radius:4px;padding:.6rem 1rem;font-family:inherit;font-weight:600;transition:background .2s}.appointment-status-col button:hover,.my-appointments-empty button:hover{background:#fee2e2}.my-appointments-empty{background:var(--bg-surface);border:1px dashed var(--border-color);text-align:center;border-radius:8px;max-width:980px;margin:2rem auto 0;padding:3rem 2rem}.my-appointments-empty h3{color:var(--text-main);margin:0 0 .8rem;font-size:1.2rem}.my-appointments-empty p{color:var(--text-muted);margin:0 0 1.5rem}@media (width<=900px){.my-appointments-stats{grid-template-columns:1fr 1fr}.my-appointment-card{grid-template-columns:1fr;justify-items:start}.appointment-status-col{justify-items:start}}@media (width<=640px){.my-appointments-page{padding:1.5rem 1rem}.my-appointments-stats{grid-template-columns:1fr}}.payment-page{background:var(--bg-main);justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:3rem 1rem;display:flex}.payment-card{background:var(--bg-surface);border:1px solid var(--border-color);width:min(100%,520px);box-shadow:var(--shadow-sm);text-align:center;border-radius:8px;padding:2.5rem}.payment-tag{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.payment-card h2{color:var(--text-main);margin:0 0 2rem;font-size:2rem;font-weight:700}.bill-summary{background:var(--bg-alt);text-align:left;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.bill-row{color:var(--text-muted);justify-content:space-between;margin-bottom:1rem;font-size:1.05rem;display:flex}.bill-total{border-top:2px dashed var(--border-color);color:var(--text-main);justify-content:space-between;margin-top:1.5rem;padding-top:1rem;font-size:1.25rem;font-weight:700;display:flex}.payment-success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:4px;margin:2rem 0;padding:1.5rem;font-size:1.1rem;font-weight:600;animation:.3s ease-in-out fadeIn}.payment-error{color:#b91c1c;background:#fef2f2;border:1px solid #fca5a5;border-radius:4px;margin:1rem 0;padding:1rem;font-weight:600}.pay-btn{cursor:pointer;background:var(--primary);color:#fff;border:none;border-radius:4px;width:100%;padding:1rem;font-family:inherit;font-size:1.1rem;font-weight:600;transition:background .2s}.pay-btn:hover:not(:disabled){background:var(--primary-dark)}.pay-btn:disabled{opacity:.7;cursor:not-allowed}.cancel-btn{width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-top:1rem;font-family:inherit;font-size:1rem;font-weight:600}.cancel-btn:hover{color:var(--text-main);text-decoration:underline}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.doctor-page{background:var(--bg-main);min-height:calc(100vh - 80px);padding:3rem 1rem}.doctor-hero{background:var(--bg-surface);border:1px solid var(--border-color);max-width:980px;box-shadow:var(--shadow-sm);border-radius:8px;margin:0 auto 2rem;padding:2.5rem}.doctor-hero h2{color:var(--text-main);margin:0 0 .5rem;font-size:clamp(2rem,3vw,2.5rem);font-weight:700}.doctor-hero p{color:var(--text-muted);margin:0;font-size:1.1rem;line-height:1.6}.doctor-hero button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:4px;margin-top:1.5rem;padding:.9rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:background .2s}.doctor-hero button:hover{background:var(--primary-dark)}.doctor-stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:1.5rem;max-width:980px;margin:0 auto;display:grid}.doctor-stat-card,.doctor-panel{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px}.doctor-stat-card{padding:1.5rem}.doctor-stat-card span{color:var(--text-muted);margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:block}.doctor-stat-card strong{color:var(--text-main);font-size:2rem;font-weight:700}.doctor-grid{grid-template-columns:1.4fr .9fr;gap:1.5rem;max-width:980px;margin:2rem auto 0;display:grid}.doctor-panel{padding:1.5rem}.doctor-panel h3{color:var(--text-main);margin:0 0 1.2rem;font-size:1.2rem;font-weight:600}.doctor-schedule{gap:1rem;display:grid}.schedule-card{border:1px solid var(--border-color);background:var(--bg-main);border-radius:6px;justify-content:space-between;align-items:center;gap:1rem;padding:1.2rem;display:flex}.schedule-card h4,.schedule-card p{margin:0}.schedule-card h4{color:var(--text-main);font-size:1.05rem;font-weight:600}.schedule-card p{color:var(--text-muted);margin-top:.4rem;font-size:.95rem}.schedule-card span{color:var(--primary);font-weight:600}.doctor-actions{gap:1rem;display:grid}.doctor-actions button{border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-main);cursor:pointer;border-radius:4px;padding:.9rem 1rem;font-family:inherit;font-size:1rem;font-weight:600;transition:background .2s}.doctor-actions button:hover{background:var(--bg-alt)}@media (width<=900px){.doctor-stats,.doctor-grid{grid-template-columns:1fr 1fr}}@media (width<=640px){.doctor-stats,.doctor-grid{grid-template-columns:1fr}.doctor-hero{padding:1.5rem}.schedule-card{flex-direction:column;align-items:start}}.doctor-appointments-page{background:var(--bg-main);min-height:calc(100vh - 80px);padding:3rem 1rem}.doctor-appointments-header{background:var(--bg-surface);border:1px solid var(--border-color);max-width:960px;box-shadow:var(--shadow-sm);border-radius:8px;justify-content:space-between;align-items:center;gap:1.5rem;margin:0 auto 2rem;padding:2.5rem;display:flex}.doctor-appointments-header h2{color:var(--text-main);margin:0 0 .5rem;font-size:clamp(2rem,3vw,2.5rem);font-weight:700}.doctor-appointments-header p{color:var(--text-muted);margin:0;font-size:1.1rem;line-height:1.6}.doctor-appointments-header button{background:var(--primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:.9rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:background .2s}.doctor-appointments-header button:hover{background:var(--primary-dark)}.doctor-appointments-list{gap:1rem;max-width:960px;margin:0 auto;display:grid}.appointment-card{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem;display:flex}.appointment-card h3{color:var(--text-main);margin:0 0 .4rem;font-size:1.1rem;font-weight:600}.appointment-card p,.appointment-card span{color:var(--text-muted);margin:0;font-size:.95rem}.appointment-card strong{color:var(--primary);margin-top:.4rem;font-weight:600;display:block}.appointment-actions{flex-wrap:wrap;gap:.8rem;margin-top:1rem;display:flex}.appointment-actions button,.admin-user-card button{border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-main);cursor:pointer;border-radius:4px;padding:.6rem 1rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .2s}.appointment-actions button:first-child{background:var(--primary);color:#fff;border-color:var(--primary)}.appointment-actions button:first-child:hover{background:var(--primary-dark)}.appointment-actions button:last-child{color:#b91c1c;background:#fef2f2;border-color:#fca5a5}.appointment-actions button:last-child:hover{background:#fee2e2}@media (width<=640px){.doctor-appointments-header{flex-direction:column;align-items:start;padding:1.5rem}.appointment-card{flex-direction:column;align-items:start}}.admin-page{background:var(--bg-main);min-height:calc(100vh - 80px);padding:3rem 1rem}.admin-hero{justify-content:space-between;align-items:end;gap:1.5rem;max-width:960px;margin:0 auto 2rem;display:flex}.admin-header{text-align:left}.admin-tag{color:var(--primary);letter-spacing:.05em;text-transform:uppercase;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.admin-header h2{color:var(--text-main);margin:0 0 .5rem;font-size:clamp(2rem,3vw,2.5rem);font-weight:700}.admin-header p{color:var(--text-muted);margin:0;font-size:1.1rem;line-height:1.6}.admin-hero-actions{flex-wrap:wrap;gap:1rem;display:flex}.admin-hero-actions button{border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-main);cursor:pointer;border-radius:4px;padding:.9rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.admin-hero-actions button:first-child{background:var(--primary);color:#fff;border-color:var(--primary)}.admin-hero-actions button:first-child:hover{background:var(--primary-dark)}.admin-hero-actions button:last-child:hover{background:var(--bg-alt)}.admin-stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:1.5rem;max-width:960px;margin:0 auto;display:grid}.admin-stat-card{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px;padding:1.5rem}.admin-stat-card span{color:var(--text-muted);margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:block}.admin-stat-card strong{color:var(--text-main);font-size:2rem;font-weight:700;line-height:1}.admin-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;max-width:960px;margin:2rem auto 0;display:grid}.admin-panel{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px;padding:1.5rem}.admin-panel h3{color:var(--text-main);margin:0 0 1.2rem;font-size:1.2rem;font-weight:600}.admin-panel ul{color:var(--text-muted);gap:.8rem;margin:0;padding-left:1.2rem;line-height:1.6;display:grid}.admin-mini-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.admin-mini-card{border:1px solid var(--border-color);background:var(--bg-main);border-radius:6px;padding:1.2rem}.admin-mini-card span{color:var(--text-muted);margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:block}.admin-mini-card strong{color:var(--text-main);font-size:1.8rem;font-weight:700}@media (width<=900px){.admin-hero{flex-direction:column;align-items:start}.admin-stats,.admin-grid{grid-template-columns:1fr 1fr}}@media (width<=640px){.admin-stats,.admin-grid,.admin-mini-stats{grid-template-columns:1fr}}.admin-users-page{background:var(--bg-main);min-height:calc(100vh - 80px);padding:3rem 1rem}.admin-users-header{justify-content:space-between;align-items:end;gap:1.5rem;max-width:960px;margin:0 auto 2rem;display:flex}.admin-users-header h2{color:var(--text-main);margin:0 0 .5rem;font-size:clamp(2rem,3vw,2.5rem);font-weight:700}.admin-users-header p{color:var(--text-muted);margin:0;font-size:1.1rem;line-height:1.6}.admin-users-header button{border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-main);cursor:pointer;border-radius:4px;padding:.9rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s}.admin-users-header button:hover{background:var(--bg-alt)}.admin-users-list{gap:1rem;max-width:960px;margin:0 auto;display:grid}.admin-user-card{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem;display:flex}.admin-user-card h3{color:var(--text-main);margin:0 0 .4rem;font-size:1.1rem;font-weight:600}.admin-user-card p,.admin-user-card span{color:var(--text-muted);margin:0;font-size:.95rem}.admin-user-card strong{color:var(--primary);margin-top:.4rem;font-weight:600;display:block}.admin-user-card button{border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-main);cursor:pointer;border-radius:4px;margin-top:1rem;padding:.6rem 1rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .2s}.admin-user-card button:hover{background:var(--bg-alt)}.admin-user-card button:disabled{opacity:.6;cursor:not-allowed}@media (width<=640px){.admin-users-header,.admin-user-card{flex-direction:column;align-items:start}}:root{--primary:#2b5c46;--primary-light:#3e7a5e;--primary-dark:#1e4231;--bg-main:#fcfcfb;--bg-surface:#fff;--bg-alt:#f3f5f2;--text-main:#2c332a;--text-muted:#6b7269;--border-color:#e5e7e3;--shadow-sm:0 2px 4px #2c332a0d;--shadow-md:0 4px 12px #2c332a14}body{color:var(--text-main);background:var(--bg-main);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,sans-serif}*{box-sizing:border-box;margin:0;padding:0}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}.glass{background:var(--bg-surface);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-alt)}::-webkit-scrollbar-thumb{background:#c3c9c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
