@charset "UTF-8";.loading-wrap{display:flex;align-items:center;gap:12px;padding:24px;justify-content:center}.spinner{width:22px;height:22px;border-radius:9999px;border:3px solid rgba(0,0,0,.12);border-top-color:#0009;animation:spin .8s linear infinite}.loading-text{font-size:.95rem;opacity:.8}html,body{margin:0;padding:0;overflow-x:hidden;width:100%;height:100%}.landingpage{width:100%;min-height:100vh;display:flex;flex-direction:column;font-family:Poppins,sans-serif;color:#1a1a1a;background-image:url(image/backgroundgaris.png),url(image/backgroundGaris2.png),url(image/backgroundGaris3.png),url(image/backgroundgaris.png),url(image/backgroundgaris4.png),linear-gradient(90deg,#fff,#f7f3fc,#eee9fa);background-repeat:no-repeat,no-repeat,no-repeat,no-repeat,no-repeat,no-repeat;background-position:left bottom 970px,left bottom 890px,right bottom 1040px,right bottom 1045px,right bottom 1060px,center center;background-size:30%,20%,50%,22%,20%,cover}.landingpage .header{display:flex;justify-content:space-between;align-items:center;padding:1rem 3rem}.landingpage .header .header-left{display:flex;align-items:center;gap:3rem}.landingpage .header .logo{display:flex;align-items:center;font-size:2rem;font-weight:700;color:#000;font-family:Playfair Display,serif}.landingpage .header .logo img{width:50px;margin-right:.5rem}.landingpage .header .nav ul{list-style:none;display:flex;gap:2rem;margin:0;padding:0}.landingpage .header .nav ul li{cursor:pointer;font-weight:700;font-size:1rem;transition:color .3s}.landingpage .header .nav ul li:hover{color:#6c63ff}.landingpage .header .header-buttons{display:flex;align-items:center;gap:1rem}.landingpage .header .header-buttons img{width:120px;cursor:pointer}.landingpage .header .header-buttons .login{background:#6c63ff;color:#fff;border:none;border-radius:8px;padding:.8rem 2rem;font-weight:600;cursor:pointer;transition:background .3s;font-size:1rem}.landingpage .header .header-buttons .login:hover{background:#594fd1}.landingpage main{flex:1;display:flex;align-items:center;justify-content:center}.landingpage main .hero{width:100%;max-width:1540px;margin:0 auto;display:flex;justify-content:space-between;padding-top:10rem;position:relative}.landingpage main .hero .hero-content{flex:1;min-width:0;max-width:600px;padding:0 6rem}.landingpage main .hero .hero-content h1{font-size:3.7rem;margin-bottom:1rem;line-height:1.2}.landingpage main .hero .hero-content p{font-size:1rem;color:#555;margin-bottom:2rem}.landingpage main .hero .hero-content .buttons{display:flex;gap:1rem}.landingpage main .hero .hero-content .buttons .get-started{background:#6c63ff;color:#fff;border:none;border-radius:8px;padding:.8rem 1.5rem;font-weight:600;cursor:pointer;transition:background .3s}.landingpage main .hero .hero-content .buttons .get-started:hover{background:#594fd1}.landingpage main .hero .hero-content .buttons .watch-video{display:inline-flex;align-items:center;gap:.5rem;background:transparent;color:#6c63ff;border:none;border-radius:8px;padding:.8rem 1.5rem;font-weight:600;cursor:pointer;transition:background .3s,color .3s}.landingpage main .hero .hero-content .buttons .watch-video:hover{background:#6c63ff;color:#fff}.landingpage main .hero .hero-content .buttons .watch-video img{height:1.8em;width:auto;display:inline-block}.landingpage main .hero .hero-content button:focus{outline:none}.landingpage main .hero .hero-image{flex:1;min-width:0;display:flex;justify-content:center;align-items:center;margin-top:-120px}.landingpage main .hero .hero-image img{width:50%;height:auto;display:block}.stats{display:flex;justify-content:center;align-items:center;gap:4rem;padding:2rem 4rem}.stats .stat-box{text-align:center}.stats .stat-box h2{font-size:60px;font-weight:700;color:#1a1a1a;margin-bottom:.5rem;padding:0rem 4rem}.stats .stat-box p{font-size:1.1rem;color:#666;margin:0}@media (max-width: 768px){.stats{flex-direction:column;gap:2rem}}.features{padding:2rem}.features h2{text-align:center;font-size:2rem;font-weight:700;margin-bottom:3rem;color:#1a1a1a}.features .feature-list{display:flex;justify-content:center;align-items:stretch;gap:2rem;flex-wrap:wrap}.features .feature-list .feature-item{padding:2rem;border-radius:1rem;box-shadow:0 8px 24px #0000000d;text-align:center;flex:1 1 280px;max-width:300px;transition:transform .3s,box-shadow .3s}.features .feature-list .feature-item:hover{transform:translateY(-5px);box-shadow:0 12px 32px #0000001a}.features .feature-list .feature-item img{width:56px;height:56px;margin-bottom:1rem}.features .feature-list .feature-item h3{font-size:1.2rem;font-weight:600;color:#1a1a1a;margin-bottom:.5rem}.features .feature-list .feature-item p{font-size:.95rem;color:#666;line-height:1.5}.footer{background:#000;color:#fff;text-align:center;padding:2rem 1rem}.footer .footer-links{display:flex;justify-content:center;gap:2rem;margin-bottom:1rem}.footer .footer-links a{color:#fff;text-decoration:none;font-weight:500;transition:color .3s}.footer .footer-links a:hover{color:#6c63ff}.footer p{font-size:.9rem;margin:0;opacity:.7}.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 3rem}.header .header-left{display:flex;align-items:center;gap:3rem}.header .logo{display:flex;align-items:center;font-size:2rem;font-weight:700;color:#000;font-family:Playfair Display,serif;cursor:pointer}.header .logo img{width:50px;margin-right:.5rem}.header .nav ul{list-style:none;display:flex;gap:2rem;margin:0;padding:0}.header .nav ul li{cursor:pointer;font-weight:700;font-size:1rem;transition:color .3s}.header .nav ul li:hover{color:#6c63ff}.header .header-buttons{display:flex;align-items:center;gap:1rem}.header .header-buttons img{width:120px;cursor:pointer}.header .header-buttons .login-header{background:#6c63ff;color:#fff;border:none;border-radius:8px;padding:.8rem 2rem;font-weight:600;cursor:pointer;transition:background .3s;font-size:1rem}.header .header-buttons .login-header:hover{background:#594fd1}.header .header-buttons .register-header{background:#6c63ff;color:#fff;border:none;border-radius:8px;padding:.8rem 2rem;font-weight:600;cursor:pointer;transition:background .3s;font-size:1rem}.header .header-buttons .register-header:hover{background:#594fd1}.login{display:flex;flex-direction:column;font-family:Poppins,sans-serif;background:#f5f7fc;min-height:100vh;min-height:100dvh;min-height:100svh}.login-header{position:relative;background:#fff;padding:.75rem 2rem;display:flex;align-items:center;box-shadow:0 2px 4px #0000000d}.login-header .login-logo{width:180px;height:auto}.login-body{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:0 1rem 6rem;min-height:0}.login-container{width:100%;max-width:380px;margin-top:80px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:.5rem 2rem;text-align:center}.login-container .logo{width:60px;margin:0 auto 1rem}.login-container h1{font-size:1.5rem;font-weight:600;margin:0 0 .25rem}.login-container p{color:#777;font-size:.9rem;margin:0 0 3rem}.login-container .login-form{display:flex;flex-direction:column;gap:1rem}.login-container .login-form .form-group{position:relative;display:flex;flex-direction:column;text-align:left}.login-container .login-form .form-group label{font-size:.85rem;color:#555;margin-bottom:.3rem}.login-container .login-form .form-group input{background:#f9fafb;border:1px solid #e0e0e0;border-radius:8px;padding:.75rem 1rem .75rem 2.5rem;font-size:1rem;outline:none;transition:border .3s,background .3s}.login-container .login-form .form-group input:focus{border-color:#6c63ff;background:#fff}.login-container .login-form .form-group input::placeholder{color:#999;transition:opacity .2s}.login-container .login-form .form-group input:focus::placeholder,.login-container .login-form .form-group input:not(:placeholder-shown)::placeholder{opacity:0}.login-container .login-form .form-group .input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:20px;height:20px;opacity:.7;pointer-events:none}.login-container .login-form .forgot-password{margin:-.5rem 0 .5rem;text-align:right;font-size:.85rem}.login-container .login-form .forgot-password a{color:#6c63ff;text-decoration:none}.login-container .login-form .forgot-password a:hover{text-decoration:underline}.login-container .login-form .btn-login{width:40%;margin:0 auto;padding:.9rem;border:none;border-radius:8px;background:#5570f1;color:#fff;font-size:17px;cursor:pointer;transition:background .3s}.login-container .login-form .btn-login:hover{background:#594fd1}.login-container .login-form .register-link{margin:1rem 0 3rem;font-size:.85rem;color:#777}.login-container .login-form .register-link a{color:#6c63ff;text-decoration:none}.login-container .login-form .register-link a:hover{text-decoration:underline}@media (max-width: 480px){.login .btn-login{width:100%}}.alert-message{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;width:fit-content;display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-radius:6px;font-family:Arial,sans-serif;max-width:420px}.alert-message .icon{display:flex;align-items:center;justify-content:center;margin-top:2px}.alert-message .icon svg{color:#2e7d32}.alert-message .content strong{display:block;font-size:1rem;font-weight:600;color:#1b1b1b;margin-bottom:.25rem;padding-right:1.5rem}.alert-message .content p{margin:0;font-size:.9rem;color:#333}.alert-message.success{background-color:#e6f4ea;border:1px solid #b7e1c0}.alert-message.success .icon svg{color:#34a853}.alert-message.error{background-color:#fdecea;border:1px solid #f5c2c0}.alert-message.error .icon svg{color:#d32f2f}.alert-message.warning{background-color:#fff8e1;border:1px solid #ffe082}.alert-message.warning .icon svg{color:#fbc02d}.alert-message.info{background-color:#e3f2fd;border:1px solid #90caf9}.alert-message.info .icon svg{color:#1976d2}:root{--input-h: 48px;--icon-size: 18px;--icon-left: 14px;--icon-gap: 10px;--text-left: calc(var(--icon-left) + var(--icon-size) + var(--icon-gap))}.register{min-height:100vh;display:flex;flex-direction:column;background:#f5f7fc;font-family:Poppins,sans-serif}.register .register-body{display:flex;justify-content:center;align-items:flex-start;flex:1;padding-bottom:6rem}.register .register-header{position:relative;background:#fff;padding:.75rem 2rem;display:flex;align-items:center;box-shadow:0 2px 4px #0000000d}.register .register-header .register-logo{width:180px;height:auto}.register .register-container{background:#fff;padding:.75rem 2rem;border-radius:12px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:380px;text-align:center;margin-top:80px;height:auto;flex:unset}.register .register-container .logo{width:60px;margin:0 auto 1rem}.register .register-container h1{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.register .register-container p{color:#777;font-size:.9rem;margin-bottom:3rem}.register .register-container .register-form{display:flex;flex-direction:column;gap:.5rem}.register .register-container .register-form .form-group{position:relative;display:flex;flex-direction:column;text-align:left;margin-bottom:0}.register .register-container .register-form .form-group label{font-size:.85rem;color:#555;margin-bottom:.3rem}.register .register-container .register-form .form-group input{height:var(--input-h);background:#f9fafb;border:1px solid #e0e0e0;border-radius:8px;padding:0 12px 0 var(--text-left);font-size:1rem;outline:none;transition:border .3s,background .3s}.register .register-container .register-form .form-group input:focus{border-color:#6c63ff;background:#fff}.register .register-container .register-form .form-group input::placeholder{color:#999;transition:opacity .2s}.register .register-container .register-form .form-group input:focus::placeholder,.register .register-container .register-form .form-group input:not(:placeholder-shown)::placeholder{opacity:0}.register .register-container .register-form .form-group .input-icon{position:absolute;left:var(--icon-left);top:50%;transform:translateY(-50%);width:var(--icon-size);height:var(--icon-size);object-fit:contain;opacity:.7;pointer-events:none}.register .register-container .register-form .form-group .form-error{margin-top:.15rem;margin-left:var(--text-left);font-size:.8rem;margin-bottom:-8px;color:#ef4444}.register .register-container .register-form .input-wrapper{position:relative;display:flex;align-items:center;height:var(--input-h)}.register .register-container .register-form .forgot-password{text-align:right;font-size:.85rem;margin-top:-.5rem}.register .register-container .register-form .forgot-password a{color:#6c63ff;text-decoration:none}.register .register-container .register-form .forgot-password a:hover{text-decoration:underline}.register .register-container .register-form .btn-register{background:#5570f1;color:#fff;border:none;border-radius:8px;padding:.9rem;font-size:17px;cursor:pointer;transition:background .3s;height:46px;display:inline-flex;align-items:center;justify-content:center;width:40%;margin:.5rem auto 0}.register .register-container .register-form .btn-register:hover{background:#594fd1}.register .register-container .register-form .register-link{margin-top:1rem;font-size:.85rem;color:#777;margin-bottom:3rem}.register .register-container .register-form .register-link a{color:#6c63ff;text-decoration:none}.register .register-container .register-form .register-link a:hover{text-decoration:underline}select{height:var(--input-h);width:100%;background:#f9fafb;border:1px solid #e0e0e0;border-radius:8px;padding:0 2.5rem 0 12px;font-size:1rem;color:#111;outline:none;transition:border .3s,box-shadow .2s;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23666'><path d='M5.23 7.21a.75.75 0 011.06.02L10 10.94l3.71-3.71a.75.75 0 111.06 1.06l-4.24 4.24a.75.75 0 01-1.06 0L5.25 8.29a.75.75 0 01-.02-1.08z'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:16px 16px}select:focus{border-color:#6c63ff;background:#fff;box-shadow:0 0 0 3px #6c63ff26}select:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.modal-alert-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:999}.modal-alert{background:#fff;padding:2rem 2.5rem;border-radius:16px;text-align:center;max-width:340px;width:100%;box-shadow:0 15px 40px #0003;animation:scaleIn .3s ease}.modal-alert h2{font-size:1.5rem;margin:.5rem 0 .2rem;color:#333}.modal-alert p{font-size:.95rem;color:#555;margin-bottom:1.5rem}.modal-alert .modal-icon{font-size:3rem;margin-bottom:1rem}.modal-alert .btn-alert-ok{padding:.7rem 2rem;background-color:#4f46e5;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .3s}.modal-alert .btn-alert-ok:hover{background-color:#4338ca}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-header .view-all{font-size:.875rem;color:#be123c;text-decoration:none;font-weight:500}.button{display:inline-flex;align-items:center;justify-content:center;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .2s ease,color .2s ease;cursor:pointer}.button:hover{background-color:#f3f4f6}.button:focus{outline:2px solid #3b82f6;outline-offset:2px}.card{border-radius:.75rem;border:1px solid #e5e7eb;background-color:#fff;padding:1rem;box-shadow:0 1px 2px #0000000d}.grid-konsultasi{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;padding:1rem}.card-konsultasi{border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden;background-color:#fff;transition:box-shadow .3s}.card-konsultasi:hover{box-shadow:0 10px 15px #0000000d}.card-konsultasi .img-wrapper{aspect-ratio:5/4;background:#f0fdf4;display:flex;align-items:center;justify-content:center}.card-konsultasi .img-wrapper img{width:70%;height:auto;object-fit:cover}.card-konsultasi .card-content{padding:1.25rem}.card-konsultasi .card-content h3{font-size:1rem;font-weight:600;margin-bottom:.25rem}.card-konsultasi .card-content .name{font-size:.875rem;color:#6b7280;margin-bottom:.75rem}.card-konsultasi .card-content .info-row{display:flex;justify-content:space-between;font-size:.875rem;color:#4b5563;margin-bottom:.5rem}.card-konsultasi .card-content .info-row svg{margin-right:4px;vertical-align:middle}.card-konsultasi .card-content .info-row .icon-star{color:#facc15;fill:#facc15}.card-konsultasi .card-content .price{font-size:1.25rem;font-weight:700;color:#111827;margin-bottom:.75rem}.card-konsultasi .card-content .btn-book{width:100%;background-color:#22c55e;color:#fffdfd;font-weight:500;padding:.5rem 0;border-radius:.5rem;transition:background .3s}.card-konsultasi .card-content .btn-book.available{background-color:#22c55e;color:#fff}.card-konsultasi .card-content .btn-book:hover{background-color:#16a34a}.card-konsultasi .card-content .btn-book:disabled{background-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.card-konsultasi .card-content .available{margin-top:.5rem;font-size:.75rem;color:#16a34a;font-weight:500}.appoinment{height:auto;min-height:100%;overflow-x:hidden;overflow-y:auto;padding:.5rem 0}.appoinment .appointment-container{max-width:1200px;margin:0 auto;padding:0rem 1rem}.appoinment .appointment-header{text-align:center;margin-bottom:2rem}.appoinment .appointment-header h1{font-size:2rem;font-weight:700;color:#1f2937}.appoinment .appointment-header p{color:#6b7280;font-size:1rem}.appoinment .appointment-main{display:flex;flex-direction:column;gap:2rem}.appoinment .appointment-sidebar{display:flex;flex-direction:column;gap:1.5rem;position:relative}.appoinment .appointment-sidebar .summary-wrapper{position:sticky;top:1rem}.appoinment .time-slot-section{background-color:#fff;border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #00000008}.appoinment .time-slot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.appoinment .time-slot-header h3{font-size:1rem;font-weight:600;color:#1f2937}.appoinment .time-slot-header span{font-size:.875rem;color:#6b7280}.appoinment .time-slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem;margin-bottom:1rem}.appoinment .time-slot-grid button{padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;border:1px solid #e5e7eb;background-color:#f9fafb;color:#374151;transition:all .2s}.appoinment .time-slot-grid button:hover{background-color:#ede9fe;border-color:#ddd6fe;color:#6b21a8}.appoinment .time-slot-grid button.active,.appoinment .time-slot-grid button.selected{background-color:#f3e8ff;border-color:#d8b4fe;color:#7e22ce;transform:scale(1.05);box-shadow:0 0 8px #a855f740}.appoinment .show-all-link{color:#7c3aed;font-size:.875rem;font-weight:500;transition:color .2s}.appoinment .show-all-link:hover{color:#6d28d9}.appoinment .patient-form{background-color:#fff;border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #00000008;display:flex;flex-direction:column;gap:1.5rem}.appoinment .patient-form .select-trigger{width:100%;height:50px;padding:0 1rem;font-size:.9rem;border:1px solid #d1d5db;border-radius:.5rem;background-color:#fff;color:#374151;display:flex;align-items:center;justify-content:space-between;transition:all .2s ease}.appoinment .patient-form .select-trigger:hover{border-color:#a78bfa}.appoinment .patient-form .select-trigger:focus-within{border-color:#a78bfa;box-shadow:0 0 0 2px #a78bfa4d}.appoinment .patient-form .select-content{border-radius:.5rem;border:1px solid #e5e7eb;background:#fff;padding:.25rem;box-shadow:0 6px 18px #0000000d}.appoinment .patient-form .select-item{padding:.6rem 1rem;font-size:.875rem;color:#374151;border-radius:.375rem;transition:background-color .2s ease}.appoinment .patient-form .select-item:hover{background-color:#f3f4f6}.appoinment .patient-form .select-item[data-state=checked]{background-color:#ede9fe;color:#6b21a8;font-weight:500}.appoinment .patient-form .bpjs-input-wrapper{margin-top:1rem}.appoinment .patient-form .bpjs-input-wrapper label{font-weight:500;font-size:.875rem;margin-bottom:.5rem;display:block}.appoinment .patient-form .bpjs-input-wrapper input{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem}.appoinment .patient-form .bpjs-input-wrapper input:focus{outline:none;border-color:#a78bfa;box-shadow:0 0 0 2px #a78bfa4d}.appoinment .patient-form h3{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.appoinment .patient-form label{font-weight:500;margin-bottom:.5rem;display:block;font-size:.875rem}.appoinment .patient-form input,.appoinment .patient-form select{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem}.appoinment .patient-form input:focus,.appoinment .patient-form select:focus{outline:none;border-color:#a78bfa;box-shadow:0 0 0 2px #a78bfa4d}.appoinment .btn-next{width:100%;background-color:#7c3aed;color:#fff;padding:.75rem 1.25rem;font-size:1rem;font-weight:500;border-radius:.5rem;box-shadow:0 4px 6px #7c3aed40;transition:all .3s}.appoinment .btn-next:hover{background-color:#6d28d9;transform:scale(1.03)}.appoinment .summary-box{margin-top:1rem;padding:1rem;background-color:#f5f3ff;border:1px solid #ddd6fe;border-radius:.75rem;color:#6b21a8}.appoinment .summary-box h4{font-weight:600;margin-bottom:.5rem;color:#5b21b6}.appoinment .summary-box p{font-size:.875rem;margin-bottom:.25rem}.textarea-keluhan{width:100%;min-height:120px;padding:1rem;font-size:1rem;line-height:1.5;border:1px solid #d1d5db;border-radius:.5rem;resize:vertical;overflow-wrap:break-word;word-break:break-word;white-space:pre-wrap;background-color:#fff}.textarea-keluhan:focus{outline:none;border-color:#a78bfa;box-shadow:0 0 0 2px #a78bfa4d}.textarea-keluhan::placeholder{color:#9ca3af;font-size:.95rem}.calendar-wrapper-konsultasi{background-color:#fff;border-radius:.75rem;padding:1.5rem}.calendar-header-konsultasi{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.calendar-header-konsultasi .calendar-month{font-size:1.125rem;font-weight:600;color:#1f2937}.calendar-header-konsultasi .calendar-nav-btn{padding:.5rem;border-radius:9999px;background:transparent;transition:background-color .2s}.calendar-header-konsultasi .calendar-nav-btn:hover{background-color:#f3f4f6}.calendar-header-konsultasi .calendar-nav-btn .calendar-nav-icon{width:1.25rem;height:1.25rem;color:#4b5563}.calendar-days-of-week{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:.5rem}.calendar-days-of-week .calendar-day-label{font-size:.875rem;font-weight:500;color:#6b7280;padding:.5rem 0}.calendar-days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.calendar-days-grid .calendar-day-btn{position:relative;width:2.5rem;height:2.5rem;font-size:.875rem;font-weight:500;border-radius:.5rem;transition:all .2s;color:#6b7280;background-color:transparent}.calendar-days-grid .calendar-day-btn:hover{background-color:#f5f3ff;color:#6d28d9}.calendar-days-grid .calendar-day-btn.selected{background-color:#7c3aed;color:#fff;box-shadow:0 2px 6px #7c3aed66;transform:scale(1.05)}.calendar-days-grid .calendar-day-btn.available{cursor:pointer}.calendar-days-grid .calendar-day-btn.disabled{color:#d1d5db;cursor:not-allowed}.calendar-days-grid .calendar-day-btn.not-current{opacity:.5}.calendar-days-grid .calendar-day-btn.past{opacity:.3}.calendar-days-grid .calendar-day-btn .calendar-dot{position:absolute;bottom:.25rem;left:50%;transform:translate(-50%);width:.25rem;height:.25rem;background-color:#c084fc;border-radius:9999px}.custom-input{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;width:100%;outline:none;transition:border-color .2s ease}.custom-input:focus{border-color:#7c3aed}.custom-input::placeholder{color:#9ca3af}.custom-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.feedback-container{max-width:800px;margin:2rem auto;padding:2.5rem;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014}.feedback-container .feedback-title{font-size:2rem;color:#2d3748;margin:0 0 .5rem;font-weight:700;line-height:1.2}.feedback-container .feedback-subtitle{color:#4a5568;margin:0 0 2.5rem;font-size:1.1rem;line-height:1.6}.feedback-container .feedback-form{display:flex;flex-direction:column;gap:2rem}.feedback-container .feedback-form-group{display:flex;flex-direction:column;gap:.75rem}.feedback-container .feedback-form-group .feedback-label{font-weight:600;color:#2d3748;font-size:.95rem;display:block;margin-bottom:.25rem}.feedback-container .feedback-form-group .feedback-label .required-asterisk{color:#e53e3e;margin-left:.15rem}.feedback-container .feedback-form-group .feedback-form-input,.feedback-container .feedback-form-group .feedback-form-textarea,.feedback-container .feedback-form-group .feedback-form-select{width:100%;padding:.875rem 2.5rem .875rem 1.25rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;line-height:1.5;color:#2d3748;background-color:#fff;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%234a5568' 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 1rem center;background-size:1em}.feedback-container .feedback-form-group .feedback-form-input::placeholder,.feedback-container .feedback-form-group .feedback-form-textarea::placeholder,.feedback-container .feedback-form-group .feedback-form-select::placeholder{color:#a0aec0}.feedback-container .feedback-form-group .feedback-form-input:focus,.feedback-container .feedback-form-group .feedback-form-textarea:focus,.feedback-container .feedback-form-group .feedback-form-select:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e133}.feedback-container .feedback-form-group .feedback-form-input:disabled,.feedback-container .feedback-form-group .feedback-form-textarea:disabled,.feedback-container .feedback-form-group .feedback-form-select:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.8}.feedback-container .feedback-form-group .feedback-form-input option,.feedback-container .feedback-form-group .feedback-form-textarea option,.feedback-container .feedback-form-group .feedback-form-select option{padding:.5rem}.feedback-container .feedback-form-group .feedback-form-input option[value=""],.feedback-container .feedback-form-group .feedback-form-textarea option[value=""],.feedback-container .feedback-form-group .feedback-form-select option[value=""]{color:#a0aec0}.feedback-container .feedback-form-group .feedback-form-select{cursor:pointer}.feedback-container .feedback-form-group .feedback-form-select::-ms-expand{display:none}.feedback-container .feedback-form-group .feedback-form-textarea{resize:vertical;min-height:140px;line-height:1.6}.feedback-container .feedback-rating-container{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin:1.5rem 0;position:relative}.feedback-container .feedback-stars-container{display:flex;gap:.5rem;padding:.5rem;background:#edf2f780;border-radius:2rem;border:2px solid #e2e8f0;box-shadow:0 1px 3px #0000000d;transition:all .3s ease}.feedback-container .feedback-stars-container:hover{background:#edf2f7cc;box-shadow:0 2px 6px #0000001a}.feedback-container .feedback-stars-container .feedback-star-button{background:none;border:none;cursor:pointer;padding:.5rem;color:#e2e8f0;transition:all .3s cubic-bezier(.4,0,.2,1);line-height:1;position:relative;border-radius:50%}.feedback-container .feedback-stars-container .feedback-star-button svg{fill:transparent;stroke:#94a3b8;stroke-width:2px}.feedback-container .feedback-stars-container .feedback-star-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#00000008;border-radius:50%;opacity:0;transform:scale(.8);transition:all .3s ease}.feedback-container .feedback-stars-container .feedback-star-button .feedback-star-icon{position:relative;z-index:1;display:block;transition:all .3s cubic-bezier(.4,0,.2,1)}.feedback-container .feedback-stars-container .feedback-star-button .feedback-star-icon svg{stroke-width:2px;stroke:#94a3b8}.feedback-container .feedback-stars-container .feedback-star-button:hover{transform:scale(1.1)}.feedback-container .feedback-stars-container .feedback-star-button:hover:before{opacity:1;transform:scale(1);background:#ffd7001a}.feedback-container .feedback-stars-container .feedback-star-button:hover svg{fill:gold;stroke:#ffc107}.feedback-container .feedback-stars-container .feedback-star-button:hover .feedback-star-icon{transform:scale(1.1)}.feedback-container .feedback-stars-container .feedback-star-button.filled{color:gold}.feedback-container .feedback-stars-container .feedback-star-button.filled svg{fill:gold;stroke:#ffc107;filter:drop-shadow(0 0 4px rgba(255,215,0,.5))}.feedback-container .feedback-stars-container .feedback-star-button.filled:after{content:"";position:absolute;top:-4px;left:-4px;right:-4px;bottom:-4px;background:#ffd70026;border-radius:50%;z-index:0;animation:pulse 1.5s infinite}.feedback-container .feedback-stars-container .feedback-star-button:active{transform:scale(.95)}.feedback-container .feedback-stars-container .feedback-star-button:focus{outline:none;box-shadow:0 0 0 3px #4299e14d}.feedback-container .feedback-rating-labels{min-height:1.5rem;width:100%;margin:.75rem 0 0;text-align:center}.feedback-container .feedback-rating-labels span{display:inline-block;font-size:.95rem;color:#4a5568;font-weight:500;padding:.25rem .75rem;background:#edf2f780;border-radius:1rem;margin-top:.5rem;transition:all .2s ease}.feedback-container .feedback-rating-labels span[data-rating="1"],.feedback-container .feedback-rating-labels span[data-rating="2"]{color:#e53e3e;background:#e53e3e1a}.feedback-container .feedback-rating-labels span[data-rating="3"]{color:#d69e2e;background:#d69e2e1a}.feedback-container .feedback-rating-labels span[data-rating="4"],.feedback-container .feedback-rating-labels span[data-rating="5"]{color:#38a169;background:#38a1691a}.feedback-container .feedback-form-actions{display:flex;justify-content:flex-end;gap:1rem;margin:2rem 0 1.5rem;padding-top:1rem;border-top:1px solid #edf2f7}.feedback-container .feedback-form-actions .feedback-button{min-width:140px;padding:.875rem 1.5rem;border-radius:8px;font-weight:600;font-size:1rem;color:#fff;background-color:#4299e1;border:none;cursor:pointer;transition:all .2s ease}.feedback-container .feedback-form-actions .feedback-button:hover:not(:disabled){background-color:#3182ce}.feedback-container .feedback-form-actions .feedback-button:disabled{background-color:#bee3f8;cursor:not-allowed}.feedback-container .feedback-error-message{background-color:#fff5f5;color:#e53e3e;padding:1rem 1.25rem;border-radius:8px;border-left:4px solid #e53e3e;font-size:.95rem;line-height:1.5;margin-bottom:1.5rem}.feedback-container .feedback-error-message a{color:#c53030;text-decoration:underline;font-weight:500}.feedback-container .feedback-error-message a:hover{text-decoration:none}@media (max-width: 768px){.feedback-container{padding:1.75rem 1.5rem;margin:1rem}.feedback-container .feedback-title{font-size:1.75rem}.feedback-container .feedback-subtitle{font-size:1.05rem}.feedback-container .feedback-form-actions{flex-direction:column-reverse;gap:.75rem}.feedback-container .feedback-form-actions .feedback-button{width:100%;padding:.875rem 1.5rem}.feedback-container .feedback-rating-container{justify-content:center}}@keyframes pulse{0%{transform:scale(1);opacity:.8}50%{transform:scale(1.05);opacity:1}to{transform:scale(1);opacity:.8}}@media print{.feedback-container{box-shadow:none;padding:0;margin:0;max-width:100%}.feedback-container .feedback-form-actions{display:none}}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;color:#333;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.mobile-chat-header{position:fixed;top:0;left:0;height:var(--header-height, 56px);background:#00a884;display:flex;padding:0 16px;padding-top:env(safe-area-inset-top,0);z-index:1000;box-shadow:0 1px 3px #0000001a;right:0;z-index:90;background:#128c7e;color:#fff;padding:12px 16px;align-items:center}@media (min-width: 769px){.mobile-chat-header{display:none}}.mobile-chat-header .back-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#fff;margin-right:8px;border-radius:50%}.mobile-chat-header .back-button:active{background:#ffffff1a}.mobile-chat-header .back-button svg{font-size:22px}.mobile-chat-header .chat-title{font-size:17px;font-weight:500;margin:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-chat-header .back-button{background:none;border:none;color:#fff;font-size:20px;margin-right:16px;display:flex;align-items:center;justify-content:center}.mobile-chat-header .chat-title{font-size:16px;font-weight:500}.chat-app{display:flex;height:100vh;width:100%;background-color:#e5ddd5;font-family:inherit;position:relative;overflow:hidden}.chat-app .chat-sidebar{width:30%;min-width:280px;max-width:380px;background-color:#fff;z-index:20;border-right:1px solid #e9edef;display:flex;flex-direction:column;height:100%;position:relative;z-index:10;transition:transform .3s ease-in-out;box-shadow:0 1px 3px #0000001a}@media (max-width: 768px){.chat-app .chat-sidebar{position:fixed;top:0;left:0;right:0;bottom:0;width:100%!important;max-width:100%!important;min-width:100%!important;z-index:1000;transform:translate(-100%);border-right:none}.chat-app .chat-sidebar .sidebar-header{padding:12px 16px;border-bottom:1px solid #e9edef}.chat-app .chat-sidebar .chat-list{height:calc(100% - 60px)}}@media (max-width: 700px){.chat-app .chat-sidebar{position:absolute;top:0;left:0;bottom:0;transform:translate(-100%)}.chat-app .chat-sidebar.show{transform:translate(0);box-shadow:0 10px 15px #0000001a}}.chat-app .chat-sidebar .sidebar-header{background-color:#f0f2f5;padding:16px;display:flex;flex-direction:column;border-bottom:1px solid #e9edef;position:relative;z-index:30}.chat-app .chat-sidebar .sidebar-header .logo-container{display:flex;justify-content:space-between;margin-bottom:12px}.chat-app .chat-sidebar .sidebar-header .logo-container .logo-and-title{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.chat-app .chat-sidebar .sidebar-header .logo-container .logo-and-title .logo{width:36px;height:36px;object-fit:contain;border-radius:4px;flex-shrink:0}.chat-app .chat-sidebar .sidebar-header .logo-container .logo-and-title .app-title{font-size:15px;font-weight:600;color:#111b21;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.chat-app .chat-sidebar .sidebar-header .user-profile{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:8px;background:#ffffffe6;transition:all .2s ease;box-shadow:0 1px 3px #0000000d;border:1px solid rgba(0,0,0,.05)}.chat-app .chat-sidebar .sidebar-header .user-profile .profile-content{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.chat-app .chat-sidebar .sidebar-header .user-profile .header-actions{margin-left:auto}.chat-app .chat-sidebar .sidebar-header .user-profile:hover{background:#fff;box-shadow:0 2px 6px #0000001a}.chat-app .chat-sidebar .sidebar-header .user-profile .user-avatar{width:40px;height:40px;border-radius:50%;background-color:#dfe5e7;overflow:hidden;flex-shrink:0;border:2px solid #fff;box-shadow:0 2px 4px #0000001a}.chat-app .chat-sidebar .sidebar-header .user-profile .user-avatar img{width:100%;height:100%;object-fit:cover}.chat-app .chat-sidebar .sidebar-header .user-profile .user-name{font-weight:600;color:#111b21;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.chat-app .chat-sidebar .sidebar-header .header-actions{display:flex;align-items:center;gap:8px;color:#54656f}.chat-app .chat-sidebar .sidebar-header .header-actions svg{cursor:pointer;font-size:20px}.chat-app .chat-sidebar .search-bar{padding:8px 16px;background-color:#f0f2f5}.chat-app .chat-sidebar .search-bar .search-container{background-color:#fff;border-radius:8px;display:flex;align-items:center;padding:5px 15px}.chat-app .chat-sidebar .search-bar .search-container input{border:none;outline:none;padding:8px 15px;width:100%;font-size:14px;background:transparent}.chat-app .chat-sidebar .search-bar .search-container svg{color:#8696a0}.chat-app .chat-sidebar .chat-list{flex:1;overflow-y:auto}.chat-app .chat-sidebar .chat-list .chat-item{display:flex;padding:12px 16px;border-bottom:1px solid #f0f2f5;cursor:pointer;transition:background-color .2s}.chat-app .chat-sidebar .chat-list .chat-item:hover{background-color:#f5f5f5}.chat-app .chat-sidebar .chat-list .chat-item.active{background-color:#f0f2f5}.chat-app .chat-sidebar .chat-list .chat-item .avatar{position:relative;margin-right:15px}.chat-app .chat-sidebar .chat-list .chat-item .avatar img{width:50px;height:50px;border-radius:50%;object-fit:cover}.chat-app .chat-sidebar .chat-list .chat-item .avatar .online-status{position:absolute;bottom:0;right:0;width:12px;height:12px;background-color:#4ad504;border:2px solid white;border-radius:50%}.chat-app .chat-sidebar .chat-list .chat-item .chat-info{flex:1;min-width:0}.chat-app .chat-sidebar .chat-list .chat-item .chat-info .chat-header{display:flex;justify-content:space-between;margin-bottom:4px}.chat-app .chat-sidebar .chat-list .chat-item .chat-info .chat-header .contact-name{font-weight:600;color:#111b21;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-app .chat-sidebar .chat-list .chat-item .chat-info .chat-header .time{font-size:11px;color:#667781;white-space:nowrap;margin-left:5px;opacity:.8}.chat-app .chat-sidebar .chat-list .chat-item .chat-info .last-message{display:flex;align-items:center}.chat-app .chat-sidebar .chat-list .chat-item .chat-info .last-message p{margin:0;font-size:14px;color:#667781;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.chat-app .chat-sidebar .chat-list .chat-item .chat-info .last-message .unread-count{background-color:#25d366;color:#fff;border-radius:10px;font-size:11px;padding:2px 6px;margin-left:5px;min-width:18px;text-align:center}.chat-app .chat-main{flex:1;display:flex;flex-direction:column;background-color:#e5ddd5;width:100%;height:100%;overflow:hidden;z-index:1;position:relative}@media (max-width: 768px){.chat-app .chat-main{width:100%;max-width:100%;margin:0;padding:0}}@media (max-width: 768px){.chat-app .chat-main{padding-top:56px;height:100%}}.chat-app .chat-main .chat-header{background-color:#f0f2f5;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e9edef;height:60px;position:fixed;top:0;left:23.85%;right:0;z-index:15;width:76%;margin:0;box-sizing:border-box}@media (max-width: 768px){.chat-app .chat-main .chat-header{padding:10px 16px;left:0;right:0;width:100%}}.chat-app .chat-main .chat-header .contact-info{display:flex;align-items:center}.chat-app .chat-main .chat-header .contact-info .avatar{position:relative;margin-right:15px}.chat-app .chat-main .chat-header .contact-info .avatar img{width:40px;height:40px;border-radius:50%;object-fit:cover}.chat-app .chat-main .chat-header .contact-info .avatar .online-status{position:absolute;bottom:0;right:0;width:10px;height:10px;background-color:#4ad504;border:2px solid #f0f2f5;border-radius:50%}.chat-app .chat-main .chat-header .contact-info .contact-details h3{margin:0;font-size:16px;font-weight:600;color:#111b21}.chat-app .chat-main .chat-header .contact-info .contact-details p{margin:2px 0 0;font-size:13px;color:#667781}.chat-app .chat-main .chat-header .header-actions{display:flex;gap:20px;color:#54656f}.chat-app .chat-main .chat-header .header-actions svg{cursor:pointer;font-size:20px}.chat-app .chat-main .messages-container{flex:1;padding:60px 12px 16px;padding-bottom:calc(var(--input-height, 70px) + 16px);overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;width:100%;box-sizing:border-box;flex-direction:column;gap:8px;background-image:url(https://web.whatsapp.com/img/bg-chat-tile-light_a4be8e74.png);background-attachment:fixed;background-color:#e5ddd5;position:relative}@media (max-width: 768px){.chat-app .chat-main .messages-container{padding:80px 12px 16px;padding-bottom:calc(var(--input-height, 70px) + 8px)}}@media (max-width: 768px){.chat-app .chat-main .messages-container{padding:15px 5%}}@media (max-width: 1000px){.chat-app .chat-main .messages-container{padding:20px 5%}}@media (max-width: 700px){.chat-app .chat-main .messages-container{padding:15px 10px}}.chat-app .chat-main .messages-container::-webkit-scrollbar{width:6px}.chat-app .chat-main .messages-container::-webkit-scrollbar-thumb{background-color:#0003;border-radius:3px}.chat-app .chat-main .messages-container::-webkit-scrollbar-track{background:transparent}.chat-app .chat-main .messages-container .date-divider{text-align:center;margin:15px 0;position:relative}.chat-app .chat-main .messages-container .date-divider span{background-color:#e1f3fb;color:#54656f;font-size:12.5px;padding:5px 12px;border-radius:7.5px;display:inline-block}.chat-app .chat-main .messages-container .date-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:#e9edef;z-index:-1}.chat-app .chat-main .messages-container .message{max-width:85%;padding:8px 12px 4px;border-radius:12px;position:relative;word-wrap:break-word;transition:transform .15s ease-in-out,opacity .15s ease-in-out;transform-origin:bottom;animation:messageIn .3s ease-in-out forwards;opacity:0;margin-bottom:4px}@media (max-width: 480px){.chat-app .chat-main .messages-container .message{max-width:90%;padding:6px 10px 3px;font-size:15px}}@keyframes messageIn{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.chat-app .chat-main .messages-container .message:hover .message-actions{opacity:1;pointer-events:auto}.chat-app .chat-main .messages-container .message.sent{align-self:flex-end;background-color:#25d366;color:#111b21;border-top-right-radius:8px;margin-left:20%}.chat-app .chat-main .messages-container .message.sent .message-info{justify-content:flex-end;color:#0009}.chat-app .chat-main .messages-container .message.sent .status{margin-left:4px;display:inline-flex;align-items:center}.chat-app .chat-main .messages-container .message.received{align-self:flex-start;background-color:#fff;border-top-left-radius:8px;margin-right:20%;box-shadow:0 1px 3px #0000001a}.chat-app .chat-main .messages-container .message.received .message-info{color:#667781}.chat-app .chat-main .messages-container .message .message-content{padding:8px 12px;border-radius:7.5px;position:relative;word-wrap:break-word;white-space:pre-wrap;font-size:14.2px;line-height:19px;color:#111b21;box-shadow:0 1px .5px #0b141a21}.chat-app .chat-main .messages-container .message .message-content p{margin:0}.chat-app .chat-main .messages-container .message .message-info{display:flex;align-items:center;margin-top:4px;font-size:11px;color:#667781;opacity:.8}.chat-app .chat-main .messages-container .message .message-info .time{margin-right:5px}.chat-app .chat-main .messages-container .message .message-info .status{display:flex;align-items:center}.chat-app .chat-main .messages-container .message .message-info .status svg{font-size:16px;margin-left:3px}.chat-app .chat-main .messages-container .message .message-info .status svg.read{color:#53bdeb}.chat-app .chat-main .message-input-container{background-color:#f0f2f5;padding:8px 16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0));display:flex;align-items:flex-end;position:fixed;bottom:0;left:0;right:0;z-index:900;border-top:1px solid #e9edef;box-shadow:0 -2px 10px #0000000d;min-height:var(--input-height, 70px);gap:8px;border-top:1px solid rgba(0,0,0,.08);position:relative;min-height:62px;box-shadow:0 -1px 3px #00000008}@media (max-width: 768px){.chat-app .chat-main .message-input-container{padding:8px 12px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0))}}@media (max-width: 768px){.chat-app .chat-main .message-input-container{padding:8px 12px 12px;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e9edef}}.chat-app .chat-main .message-input-container .emoji-button,.chat-app .chat-main .message-input-container .attachment-button,.chat-app .chat-main .message-input-container .send-button{color:#54656f;background:none;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.chat-app .chat-main .message-input-container .emoji-button:hover,.chat-app .chat-main .message-input-container .attachment-button:hover,.chat-app .chat-main .message-input-container .send-button:hover{background-color:#0000000a;color:#00a884}.chat-app .chat-main .message-input-container .emoji-button.active,.chat-app .chat-main .message-input-container .attachment-button.active,.chat-app .chat-main .message-input-container .send-button.active{color:#00a884}.chat-app .chat-main .message-input-container .emoji-button svg,.chat-app .chat-main .message-input-container .attachment-button svg,.chat-app .chat-main .message-input-container .send-button svg{width:24px;height:24px}.chat-app .chat-main .message-input-container .input-wrapper{flex:1;background-color:#fff;border-radius:24px;display:flex;align-items:center;padding:9px 16px;margin:0;box-shadow:0 1px 2px #0000000d;transition:all .2s ease}.chat-app .chat-main .message-input-container .input-wrapper textarea{flex:1;border:none;outline:none;resize:none;font-family:inherit;font-size:15px;max-height:100px;overflow-y:auto;color:#111b21;background:transparent;line-height:1.4;padding:0;line-height:20px}.chat-app .chat-main .message-input-container .input-wrapper textarea::placeholder{color:#a0a7ac}.chat-app .chat-main .message-input-container .input-wrapper textarea::placeholder{color:#9ca3aa}.chat-app .chat-main .message-input-container .send-button{background:#128c7e;border:none;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease-in-out;flex-shrink:0}.chat-app .chat-main .message-input-container .send-button:hover:not(:disabled){background:#075e54;transform:scale(1.05)}.chat-app .chat-main .message-input-container .send-button:active:not(:disabled){transform:scale(.95)}.chat-app .chat-main .message-input-container .send-button:disabled{background:#e9edef;color:#667781;cursor:not-allowed}.chat-app .chat-main .message-input-container .send-button svg{width:20px;height:20px}.chat-app .chat-main .mobile-sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s ease-in-out;-webkit-tap-highlight-color:transparent}@media (min-width: 769px){.chat-app .chat-main .mobile-sidebar-overlay{display:none!important}}@media (max-width: 768px){.chat-app .chat-main .mobile-sidebar-overlay.show{opacity:1;visibility:visible}}@media (max-width: 768px){.chat-app .chat-main :root{--safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);--header-height: 56px;--input-height: 70px;--message-padding: 8px 12px;--bubble-radius: 18px}.chat-app .chat-main html,.chat-app .chat-main body,.chat-app .chat-main #root{height:100%}.chat-app .chat-main .chat-app{height:100vh;max-width:100%;margin:0;border-radius:0;position:fixed;top:0;left:0;right:0;bottom:0}.chat-app .chat-main .chat-app .chat-container{height:100%;border-radius:0}.chat-app .chat-main html,.chat-app .chat-main body,.chat-app .chat-main #root{height:100%;width:100%;margin:0;padding:0;overflow:hidden;-webkit-text-size-adjust:100%}.chat-app .chat-main .message-input-container{position:fixed;bottom:0;left:0;right:0;background:#f0f2f5;padding:8px 12px;display:flex;align-items:center;border-top:1px solid #e9edef;z-index:100}.chat-app .chat-main .message-input-container .emoji-button,.chat-app .chat-main .message-input-container .send-button{background:none;border:none;font-size:24px;color:#54656f;padding:8px;margin:0 4px}.chat-app .chat-main .message-input-container .message-input{flex:1;background:#fff;border:none;border-radius:20px;padding:8px 16px;font-size:14px;margin:0 8px;max-height:120px;resize:none;outline:none}.chat-app .chat-main .message-input-container .message-input::placeholder{color:#9ca3aa}}.chat-app .chat-main .sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:900;opacity:0;pointer-events:none;transition:opacity .3s ease}.chat-app .chat-main .sidebar-overlay.visible{opacity:1;pointer-events:auto}::-webkit-scrollbar{display:none;width:0;background:transparent}html,body,#root{width:100%;height:100%;margin:0;padding:0;scrollbar-width:none;touch-action:pan-x pan-y;overscroll-behavior-y:contain}body{position:fixed;width:100%;height:100%}.sidebar-open{overflow:hidden;height:100vh;width:100vw;position:fixed;touch-action:none}.sidebar-open .chat-sidebar{transform:translate(0)!important;box-shadow:2px 0 10px #0003}.sidebar-open .mobile-sidebar-overlay{opacity:1;visibility:visible;display:block}.sidebar-open .chat-main{transform:translate(100%)}@media (min-width: 769px){.sidebar-open .chat-main{transform:none}}@media (max-width: 768px){.sidebar-open .chat-main{display:none}.sidebar-open body{position:fixed;overflow:hidden;width:100%;height:100%}}.message{animation:fadeIn .2s ease-out}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;color:#1e293b;background-color:#f8fafc}.profile-container{max-width:100%;min-height:85vh;color:#1e293b}.profile-loading{display:flex;justify-content:center;align-items:center;min-height:80vh}.profile-loading .spinner{animation:spin 1s linear infinite;color:#2563eb}.error-message{background-color:#ef44441a;color:#ef4444;padding:.75rem 1rem;border-radius:12px;margin:1rem 0;font-size:.9rem;border-left:3px solid #ef4444;animation:fadeIn .3s ease-out}.profile-header{position:relative;display:flex;justify-content:space-between;align-items:center;padding:1rem 0}.profile-header h1{font-size:1.5rem;font-weight:600;margin:0;color:#1e293b;flex-grow:1;text-align:center;padding:0 2rem}.profile-header .back-button,.profile-header .edit-button{display:flex;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;border-radius:50%;margin-right:2rem;border:none;background:#2563eb1a;color:#2563eb;cursor:pointer;transition:all .3s ease}.profile-header .back-button:hover,.profile-header .edit-button:hover{background:#2563eb33;transform:translateY(-1px)}.profile-header .back-button:active,.profile-header .edit-button:active{transform:translateY(0)}.profile-header .action-buttons{display:flex;gap:.75rem}.profile-header .action-buttons .cancel-button,.profile-header .action-buttons .save-button{display:flex;justify-content:center;align-items:center;padding:.5rem;border:none;border-radius:12px;font-weight:500;cursor:pointer;transition:all .3s ease}.profile-header .action-buttons .cancel-button:disabled,.profile-header .action-buttons .save-button:disabled{opacity:.6;cursor:not-allowed}.profile-header .action-buttons .cancel-button{background:#ef44441a;color:#ef4444}.profile-header .action-buttons .cancel-button:hover:not(:disabled){background:#ef444433}.profile-header .action-buttons .save-button{background:#2563eb;color:#fff;padding:.5rem 1rem;gap:.5rem}.profile-header .action-buttons .save-button:hover:not(:disabled){background:#1350d4;box-shadow:0 2px 8px #2563eb4d}.profile-header .action-buttons .save-button:active:not(:disabled){transform:translateY(1px)}@media (max-width: 480px){.profile-header h1{font-size:1.25rem;padding:0 1rem}.profile-header .action-buttons{gap:.5rem}.profile-header .action-buttons .save-button span{display:none}}.profile-content{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:1.5rem;margin-bottom:1.5rem;max-width:600px;margin:0 auto;animation:fadeIn .4s ease-out}@media (min-width: 768px){.profile-content{padding:2.5rem}}.profile-photo-container{display:flex;justify-content:center;align-items:center;margin:0 auto 2.5rem}.profile-photo-container .profile-photo{position:relative;width:140px;height:140px;border-radius:50%;overflow:hidden;border:4px solid white;box-shadow:0 4px 12px #0000001a;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);transition:all .3s ease}.profile-photo-container .profile-photo:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001f}.profile-photo-container .profile-photo:hover .photo-upload{opacity:1;transform:translateY(0)}.profile-photo-container .profile-photo img{width:100%;height:100%;object-fit:cover;transition:all .3s ease}.profile-photo-container .profile-photo img.editable{cursor:pointer}.profile-photo-container .profile-photo .photo-upload{display:flex;justify-content:center;align-items:center;position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(transparent,#000000b3);color:#fff;cursor:pointer;opacity:0;transform:translateY(10px);transition:all .3s ease}.profile-photo-container .profile-photo .photo-upload:hover{background:linear-gradient(transparent,#000c)}.profile-photo-container .profile-photo .photo-upload svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}@media (max-width: 480px){.profile-photo-container .profile-photo{width:120px;height:120px}}.profile-form .form-group{margin-bottom:1.75rem}.profile-form .form-group:last-child{margin-bottom:.5rem}.profile-form .form-group label{display:flex;align-items:center;margin-bottom:.75rem;font-weight:500;color:#64748b;font-size:.95rem}.profile-form .form-group label .input-icon{margin-right:.75rem;color:#2563eb;width:1.25rem;text-align:center}.profile-form .form-group .input-wrapper{position:relative}.profile-form .form-group .input-wrapper:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:#2563eb;transform:scaleX(0);transform-origin:left;transition:all .3s ease}.profile-form .form-group .input-wrapper:focus-within:after{transform:scaleX(1)}.profile-form .form-group input{width:100%;padding:.875rem 1rem;border:none;border-bottom:2px solid #e2e8f0;background-color:transparent;font-size:1rem;color:#1e293b;transition:all .3s ease}.profile-form .form-group input::placeholder{color:#9da8b8}.profile-form .form-group input:focus{outline:none;border-color:transparent}.profile-form .form-group input:focus::placeholder{color:transparent}.profile-form .form-group input:disabled{background-color:transparent;opacity:.7;cursor:not-allowed}.profile-form .form-group input.error{border-color:#ef4444}.profile-form .form-group input.error::placeholder{color:#f7a2a2}.profile-form .form-group .info-value{padding:.875rem 1rem;background-color:#fff;border-radius:12px;min-height:52px;display:flex;align-items:center;color:#1e293b;font-weight:500;border:1px solid #e2e8f0;transition:all .3s ease}.profile-form .form-group .info-value:empty:after{content:"Tidak ada data";color:#64748b;font-style:italic;font-weight:400}.profile-form .form-group input[type=date]{-moz-appearance:none;appearance:none;-webkit-appearance:none}.profile-form .form-group input[type=date]::-webkit-calendar-picker-indicator{opacity:0;position:absolute;right:0;width:100%;height:100%;cursor:pointer}.profile-form .form-group input[type=date]::-webkit-datetime-edit{color:#1e293b}.profile-form .form-group input[type=date]::-webkit-datetime-edit-fields-wrapper{padding:0}.profile-form .form-group input[type=date]::-webkit-datetime-edit-text{padding:0 .25rem}@media (max-width: 480px){.profile-form .form-group{margin-bottom:1.5rem}.profile-form .form-group label{font-size:.9rem;margin-bottom:.5rem}.profile-form .form-group input,.profile-form .form-group .info-value{padding:.75rem;font-size:.95rem}.profile-form .form-group .info-value{min-height:48px}}@media (max-width: 640px){.profile-content{padding:1.5rem}.profile-photo-container .profile-photo{width:100px;height:100px}.profile-form .form-group{margin-bottom:1.25rem}.profile-form .form-group input,.profile-form .form-group .info-value{padding:.625rem .875rem;font-size:.9375rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.profile-content{animation:fadeIn .3s ease-out}.loading-skeleton{background:linear-gradient(90deg,#f8fafc 25%,#e2e8f0,#f8fafc 75%);background-size:200% 100%;animation:pulse 1.5s ease-in-out infinite;border-radius:12px;min-height:44px}@media (max-width: 480px){.profile-content{padding:1.25rem}.profile-header h1{font-size:1.25rem}.profile-photo-container .profile-photo{width:100px;height:100px}.profile-form .form-group{margin-bottom:1rem}.profile-form .form-group label{font-size:.9rem}.profile-form .form-group input,.profile-form .form-group .info-value{padding:.5rem .75rem;font-size:.9rem}}.role-admin{padding:1.5rem;max-width:1400px;margin:0 auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--gray-800)}.role-admin .page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.role-admin .page-header h1{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin:0 0 .5rem}.role-admin .page-header p{color:var(--gray-600);margin:0;font-size:.95rem}.role-admin .card{background:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);overflow:hidden;margin-bottom:2rem}.role-admin .card .card-header-role{padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.role-admin .search-box-role{--search-h: 44px;position:relative;max-width:100%;min-width:280px;flex:0 1 clamp(360px,48vw,640px);display:flex;gap:12px}.role-admin .search-box-role textarea{width:100%;padding-left:10px;padding-top:5px;padding-bottom:-10px;border:2px solid var(--gray-400);border-radius:6px;font-size:.9rem;transition:var(--transition);margin-right:1rem;resize:none;font-family:Gill Sans,sans-serif}.role-admin .search-box-role textarea:focus{outline:none;border-color:var(--primary);border-width:2px;box-shadow:0 0 0 3px #4361ee26}.role-admin .search-box-role textarea::placeholder{font-family:Gill Sans,sans-serif}.role-admin .search-box-role .search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--gray-500);display:flex;align-items:center;justify-content:center}.role-admin .search-box-role .btn-role.btn-primary{height:40px;padding:0 10px;white-space:nowrap}.role-admin .search-box-role .btn-role.btn-primary:hover{background-color:#2563eb}.role-admin .search-box-role .btn-role.btn-primary:active{background-color:#1d4ed8}.role-admin .search-box-role .btn-role.btn-primary:disabled{background-color:#a5b4fc;cursor:not-allowed}.role-admin .role-summary{display:flex;gap:1rem;flex-wrap:wrap;padding-left:30px}.role-admin .role-summary .role-summary-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem .5rem .75rem;background:var(--gray-100);border-radius:20px;font-size:.85rem;transition:var(--transition)}.role-admin .role-summary .role-summary-item:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.role-admin .role-summary .role-summary-item .role-badge{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:600}.role-admin .role-summary .role-summary-item .role-badge[class*=role-]{color:#fff;box-shadow:0 2px 4px #0000001a}.role-admin .role-summary .role-summary-item .role-badge.role-dokter{background-color:var(--success)}.role-admin .role-summary .role-summary-item .role-badge.role-psikolog{background-color:var(--info)}.role-admin .role-summary .role-summary-item .role-badge.role-karyawan{background-color:var(--warning)}.role-admin .role-summary .role-summary-item .role-badge.role-mahasiswa{background-color:var(--gray-400)}.role-admin .role-summary .role-summary-item .role-badge svg{width:16px;height:16px}.role-admin .role-summary .role-summary-item .role-count{font-weight:600;color:var(--gray-800)}.role-admin .role-summary .role-summary-item .role-label{color:var(--gray-600);white-space:nowrap}.role-admin .table-responsive{width:100%;overflow-x:auto;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:1rem}.role-admin .user-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.role-admin .user-table .user-head-table{background:#f9fafb}.role-admin .user-table .user-head-table th{text-align:left;padding:12px 16px;font-weight:600;color:#374151;font-size:13px;border-bottom:1px solid #e5e7eb;border-right:none;border:none}.role-admin .user-table .user-head-table th:nth-child(1){padding-left:10px}.role-admin .user-table .user-head-table th:nth-child(2){padding-left:28px}.role-admin .user-table .user-head-table th:nth-child(3){padding-left:40px}.role-admin .user-table .user-head-table th:nth-child(5){padding-left:90px}.role-admin .user-table .data-user tr{border-bottom:1px solid #f1f1f1;transition:background .2s}.role-admin .user-table .data-user tr:hover{background:#f9f9fb}.role-admin .user-table .data-user tr td{padding:12px 16px;vertical-align:middle;color:#374151;border:none}.role-admin .user-table .data-user tr td .user-cell{display:flex;align-items:center;gap:10px}.role-admin .user-table .data-user tr td .user-cell img{width:34px;height:34px;border-radius:50%;object-fit:cover}.role-admin .user-table .data-user tr td .user-cell .user-name{font-weight:500;color:#111827}.role-admin .user-table .data-user tr td .role-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:4px 10px;border-radius:20px}.role-admin .user-table .data-user tr td .role-badge.role-1{background:#dbeafe;color:#1d4ed8}.role-admin .user-table .data-user tr td .role-badge.role-2{background:#46c04c;color:#f1f1f1}.role-admin .user-table .data-user tr td .role-badge.role-3{background:#508acc;color:#edf0ee}.role-admin .user-table .data-user tr td .role-badge.role-4{background:#fd902a;color:#fff}.role-admin .user-table .data-user tr td .role-badge.role-5{background:#f0f0f0;color:#000}.role-admin .user-table .data-user tr td .action-buttons{display:flex;align-items:center;gap:8px}.role-admin .user-table .data-user tr td .action-buttons .btn-action{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;border:none;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s ease}.role-admin .user-table .data-user tr td .action-buttons .btn-action svg{font-size:14px}.role-admin .user-table .data-user tr td .action-buttons .btn-action.btn-edit{background:#e0f2fe;color:#0369a1}.role-admin .user-table .data-user tr td .action-buttons .btn-action.btn-edit:hover{background:#bae6fd}.role-admin .user-table .data-user tr td .action-buttons .btn-action.btn-delete{background:#fee2e2;color:#b91c1c}.role-admin .user-table .data-user tr td .action-buttons .btn-action.btn-delete:hover{background:#fecaca}.role-admin .user-table .data-user tr td .action-buttons .btn-action.btn-warning{background:#fef9c3;color:#92400e}.role-admin .user-table .data-user tr td .action-buttons .btn-action.btn-warning:hover{background:#fde68a}.role-admin .user-table .data-user tr td:nth-child(2){padding-left:28px}.role-admin .user-table .data-user tr .no-results{text-align:center;padding:40px;color:#6b7280}.role-admin .user-table .data-user tr .no-results h3{margin-top:8px;font-size:15px}.role-admin .btn-action{height:32px;padding:0 12px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid transparent;cursor:pointer;transition:var(--transition);font-size:.85rem;font-weight:500;white-space:nowrap}.role-admin .btn-action svg{width:14px;height:14px;flex-shrink:0}.role-admin .btn-action:hover{transform:translateY(-1px);box-shadow:0 1px 3px #0000000d}.role-admin .btn-action.btn-edit{color:var(--primary);background-color:var(--primary-light);border-color:#4361ee33}.role-admin .btn-action.btn-edit:hover{background-color:#e4eaff}.role-admin .btn-action.btn-delete{color:var(--danger);background-color:var(--danger-light);border-color:#ef444433}.role-admin .btn-action.btn-delete:hover{background-color:#fed8d8}.role-admin .pagination-role{display:flex;justify-content:center;align-items:center;gap:8px;padding:6px;background:#f1f3f5;border-radius:12px;width:fit-content;margin:1rem auto 0}.role-admin .pagination-role .page-btn{width:36px;height:36px;border:0;outline:0;border-radius:10px;background:#fff;color:#6b7280;font-weight:700;font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #1018280f;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,color .12s ease}.role-admin .pagination-role .page-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1018281a}.role-admin .pagination-role .page-btn:focus-visible{box-shadow:0 0 0 3px #2563eb40}.role-admin .pagination-role .page-btn.is-active{background:#1f2a44;color:#fff}.role-admin .pagination-role .page-btn.nav-btn{width:36px;min-width:36px}.role-admin .pagination-role .page-btn.nav-btn svg{display:block}.role-admin .pagination-role .page-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:0 2px 6px #1018280a}@media (max-width: 420px){.role-admin .pagination-role{gap:6px}.role-admin .pagination-role .page-btn{width:32px;height:32px;border-radius:8px;font-size:13px}}@media (max-width: 1024px){.role-admin .card-header{flex-direction:column;align-items:stretch}.role-admin .search-box{max-width:100%}}@media (max-width: 768px){.role-admin{padding:1rem}.role-admin .action-buttons{flex-direction:column;gap:.5rem}.role-admin .btn-action{width:100%;justify-content:center}.role-admin .role-summary{overflow-x:auto;padding-bottom:.5rem;margin:0 -.25rem;padding:0 .25rem .5rem}.role-admin .role-summary::-webkit-scrollbar{height:4px}.role-admin .role-summary::-webkit-scrollbar-thumb{background-color:var(--gray-300);border-radius:2px}.role-admin .role-summary-item{flex-shrink:0}}@media (max-width: 576px){.role-admin .modal-content,.role-admin .confirmation-dialog{margin:.5rem;width:calc(100% - 1rem)}.role-admin .modal-body{padding:1.25rem}.role-admin .search-box-role textarea::placeholder{font-size:.8rem}.role-admin .role-option .role-desc{display:none!important}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:#fff;padding:2rem;width:400px;max-width:90%;border-radius:12px;box-shadow:0 4px 12px #00000026;animation:fadeIn .3s ease}.modal-header{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem}.modal-header h3{display:flex;align-items:center;font-size:1.25rem;gap:.5rem;margin:0}.modal-header .text-muted{font-size:.875rem;color:#888}.modal-body .form-group input{padding:.5rem .75rem;font-size:1rem;border:1px solid #ccc;border-radius:8px;outline:none}.modal-body .form-group input:focus{border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e233}.modal-footer .btn{padding:.5rem 1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer}.modal-footer .btn.btn-outline:hover{background-color:#f5f5f5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:flex-start;justify-content:center;padding:max(48px,env(safe-area-inset-top)) 16px max(32px,env(safe-area-inset-bottom));overflow-y:auto;overscroll-behavior:contain;z-index:999}.modal-content{background:#fff;padding:2rem;width:100%;max-width:500px;border-radius:12px;box-shadow:0 10px 25px #00000026;animation:fadeIn .2s ease-in-out}.modal-header{margin-bottom:1.25rem}.modal-header h3{display:flex;align-items:center;font-size:1.25rem;font-weight:600;gap:.5rem;margin:0}.modal-header .text-muted{color:#888;font-size:.875rem}.modal-body .form-group{display:flex;flex-direction:column;margin-bottom:1rem}.modal-body .form-group label{font-weight:600;margin-bottom:.5rem}.modal-body .form-group input,.modal-body .form-group select{padding:.5rem .75rem;font-size:1rem;border:1px solid #ccc;border-radius:8px;outline:none;transition:border-color .2s ease}.modal-body .form-group input:focus,.modal-body .form-group select:focus{border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e233}.modal-footer{display:flex;justify-content:flex-end;gap:1rem}.modal-footer .btn{padding:.5rem 1.25rem;font-weight:600;font-size:.95rem;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.modal-footer .btn.btn-outline{background-color:transparent;border:1px solid #ccc;color:#333}.modal-footer .btn.btn-outline:hover{background-color:#f0f0f0}.modal-footer .btn.btn-primary{background-color:#4a90e2;color:#fff}.modal-footer .btn.btn-primary:hover{background-color:#3b7cc4}.dashboard-sidebar{position:sticky;top:0;width:250px;height:100dvh;overflow:hidden;background-color:#fff;color:#111827;display:flex;flex-direction:column;padding:1.5rem 1rem;border-right:1px solid #e5e7eb}.dashboard-sidebar .sidebar-header{display:flex;align-items:center;gap:.5rem;padding:0 .75rem;margin-bottom:2rem}.dashboard-sidebar .sidebar-header .logo-icon{width:32px;height:32px}.dashboard-sidebar .sidebar-header .logo-text{font-weight:700;font-size:1.2rem}.dashboard-sidebar .sidebar-nav{flex-grow:1;flex:1 1 auto;overflow-y:auto;padding-bottom:140px}.dashboard-sidebar .sidebar-nav ul{list-style:none;padding:0;margin:0}.dashboard-sidebar .sidebar-nav ul .logo-icon-home,.dashboard-sidebar .sidebar-nav ul .logo-icon-consult{width:20px;height:20px}.dashboard-sidebar .sidebar-nav ul .nav-item{display:flex;align-items:center;justify-content:flex-start;padding:.75rem 1rem;margin-bottom:.5rem;border-radius:8px;font-weight:500;cursor:pointer;position:relative;transition:background .3s}.dashboard-sidebar .sidebar-nav ul .nav-item:hover{background-color:#e0e7ff}.dashboard-sidebar .sidebar-nav ul .nav-item.active{background-color:#3b82f6;color:#fff}.dashboard-sidebar .sidebar-nav ul .nav-item.active .badge{background-color:#fff;color:#3b82f6}.dashboard-sidebar .sidebar-nav ul .nav-item .icon{text-decoration:none;margin-right:12px;font-size:1.1rem;color:#111827;display:flex;align-items:center;justify-content:center;width:24px}.dashboard-sidebar .sidebar-nav ul .nav-item .label{flex:1;text-align:left}.dashboard-sidebar .sidebar-nav ul .nav-item .badge{background-color:#facc15;color:#111827;font-size:.75rem;padding:.2rem .5rem;border-radius:999px;margin-left:auto}.dashboard-sidebar .sidebar-nav ul .nav-item .badge.orange{background-color:#f97316;color:#fff}.dashboard-sidebar .sidebar-bottom{position:sticky;bottom:0;background:#fff;padding-top:.75rem;padding-bottom:.75rem;border-top:1px solid #e5e7eb;box-shadow:0 -8px 16px #1118270a;z-index:1}.dashboard-sidebar .sidebar-bottom .sidebar-extra{margin-top:0}.dashboard-sidebar .sidebar-bottom .sidebar-extra .contact-btn{width:100%;padding:1rem;background-color:#f3f4f6;border-radius:8px;font-weight:500;margin-bottom:.75rem;text-align:left;border:none;display:flex;align-items:center;gap:.5rem}.dashboard-sidebar .sidebar-bottom .sidebar-extra .contact-btn .icon{text-decoration:none;color:#6b7280}.dashboard-sidebar .sidebar-bottom .sidebar-extra .gift-card{background:#fff7ed;padding:.75rem;border-radius:10px;display:flex;gap:.75rem;align-items:center;font-size:.875rem;box-shadow:0 0 0 1px #f97316}.dashboard-sidebar .sidebar-bottom .sidebar-extra .gift-card p{margin:0;font-weight:700}.dashboard-sidebar .sidebar-bottom .sidebar-extra .gift-card small{color:#9ca3af}.dashboard-sidebar .sidebar-bottom .sidebar-extra .gift-card .icon{text-decoration:none;color:#f97316}.dashboard-sidebar .sidebar-bottom .sidebar-footer{padding-top:.75rem;border-top:1px solid #e5e7eb}.dashboard-sidebar .sidebar-bottom .sidebar-footer .logout-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:12px;--danger-bg: #fff1f2;--danger-bg-hover: #ffe4e6;--danger-border: #fecaca;--danger-text: #b91c1c;--danger-strong: #ef4444;background:linear-gradient(180deg,var(--danger-bg),#ffffff);color:var(--danger-text);border:1px solid var(--danger-border);font-weight:700;line-height:1;cursor:pointer;position:relative;transition:transform .15s ease,box-shadow .2s ease,color .2s ease,background-color .2s ease,border-color .2s ease;text-decoration:none}.dashboard-sidebar .sidebar-bottom .sidebar-footer .logout-btn .icon{text-decoration:none;font-size:1.1rem;transition:transform .2s ease,color .2s ease}.dashboard-sidebar .sidebar-bottom .sidebar-footer .logout-btn:hover{background-color:var(--danger-bg-hover);border-color:var(--danger-strong);color:var(--danger-strong)}.dashboard-sidebar .sidebar-bottom .sidebar-footer .logout-btn:hover .icon{text-decoration:none;color:var(--danger-strong);transform:translate(2px)}.dashboard-sidebar .sidebar-bottom .sidebar-footer .logout-btn:active{transform:translateY(0);box-shadow:none}.dashboard-sidebar .sidebar-bottom .sidebar-footer .logout-btn:focus-visible{outline:none;box-shadow:0 0 0 4px #ef444426,0 1px #00000005 inset}.dashboard-sidebar .sidebar-bottom .sidebar-footer .logout-btn:disabled,.dashboard-sidebar .sidebar-bottom .sidebar-footer .logout-btn[aria-busy=true],.dashboard-sidebar .sidebar-bottom .sidebar-footer .logout-btn[data-loading=true]{opacity:.7;cursor:not-allowed;pointer-events:none}.dashboard-sidebar .sidebar-bottom .sidebar-footer .logout-btn[data-loading=true]:after{content:"";position:absolute;right:12px;width:16px;height:16px;border-radius:9999px;border:2px solid currentColor;border-top-color:transparent;animation:spin .8s linear infinite}.dashboard-sidebar .sidebar-footer .logout-btn:hover{text-decoration:none!important}@keyframes spin{to{transform:rotate(360deg)}}@media (min-width: 1600px){.dashboard-sidebar{width:300px;padding:2rem 1.25rem}.dashboard-sidebar .sidebar-nav ul .nav-item{padding:.85rem 1rem}}@media (min-width: 1280px) and (max-width: 1599px){.dashboard-sidebar{width:260px}}@media (min-width: 1024px) and (max-width: 1279px){.dashboard-sidebar{width:230px}.dashboard-sidebar .sidebar-nav ul .nav-item{padding:.65rem .9rem}}@media (min-width: 768px) and (max-width: 1023px) and (orientation: portrait){.dashboard-sidebar{width:220px}.dashboard-sidebar .sidebar-header .logo-text{font-size:1.1rem}}@media (max-width: 767px){.dashboard-sidebar{position:fixed;inset:0 auto 0 0;width:min(88vw,320px);transform:translate(-100%);transition:transform .25s ease;box-shadow:8px 0 24px #00000014;z-index:40}.dashboard-sidebar.is-open{transform:translate(0)}.dashboard-sidebar .sidebar-header{margin-bottom:1rem}.dashboard-sidebar .sidebar-nav{padding-bottom:110px}.dashboard-sidebar .sidebar-bottom{position:fixed;left:0;right:auto;bottom:0;width:inherit}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:30}.sidebar-backdrop.is-open{opacity:1;pointer-events:auto}}@media (max-width: 414px){.dashboard-sidebar{width:86vw}}@media (max-width: 375px){.dashboard-sidebar{width:88vw}.dashboard-sidebar .sidebar-nav ul .nav-item .label{font-size:.95rem}}@media (max-width: 320px){.dashboard-sidebar{width:92vw}.dashboard-sidebar .sidebar-nav ul .nav-item{padding:.6rem .8rem}.dashboard-sidebar .sidebar-nav ul .nav-item .label{font-size:.9rem}}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;margin:0 -2rem 2rem;background-color:#fff;border-bottom:1px solid #e5e7eb;border-radius:0 0 12px 12px;position:sticky;top:0;z-index:5}.dashboard-header h1{font-size:1.6rem;font-weight:600;color:#111827}.dashboard-header .header-actions{display:flex;align-items:center;gap:1rem}.dashboard-header .header-actions .user-btn{background:#fff7ed;border:none;padding:.4rem .8rem;border-radius:10px;font-size:.95rem;color:#333;font-weight:500;box-shadow:0 2px 6px #0000000d;display:flex;align-items:center;gap:.4rem;cursor:pointer}.dashboard-header .header-actions .user-btn .arrow{font-size:.75rem;color:#6b7280}.dashboard-header .header-actions .notification-btn{background:none;border:none;font-size:1.2rem;color:#3b82f6;cursor:pointer;position:relative}.dashboard-header .header-actions .notification-btn .icon{width:20px}.dashboard-header .header-actions .notification-btn:hover{opacity:.8}.dashboard-header .header-actions .profile-avatar{width:30px;border-radius:50%;object-fit:cover;border:2px solid #ddd}.dashboard-header .menu-toggle{display:none}@media (min-width: 1600px){.dashboard-header{padding:1.25rem 2.5rem}.dashboard-header h1{font-size:1.8rem}.dashboard-header .header-actions{gap:1.25rem}}@media (min-width: 1280px) and (max-width: 1599px){.dashboard-header{padding:1rem 2rem}}@media (min-width: 1024px) and (max-width: 1279px){.dashboard-header{padding:.85rem 1.5rem}.dashboard-header h1{font-size:1.45rem}.dashboard-header .header-actions{gap:.85rem}}@media (min-width: 768px) and (max-width: 1023px) and (orientation: portrait){.dashboard-header{padding:.75rem 1.25rem}.dashboard-header h1{font-size:1.35rem}.dashboard-header .header-actions .user-btn{padding:.35rem .7rem}}@media (max-width: 767px){.dashboard-header{padding:.65rem 1rem;gap:.5rem}.dashboard-header .menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.dashboard-header .menu-toggle img{width:20px;height:20px;display:block}.dashboard-header .menu-toggle .bar{display:block;width:18px;height:2px;background:#111827;border-radius:1px}.dashboard-header .menu-toggle .bar+.bar{margin-top:4px}.dashboard-header .menu-toggle:hover{background:#f9fafb;border-color:#d1d5db}.dashboard-header .menu-toggle:focus-visible{outline:none;box-shadow:0 0 0 3px #3b82f640}.dashboard-header h1{font-size:1.2rem;flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-header .header-actions{gap:.6rem}.dashboard-header .header-actions .user-btn{display:none}.dashboard-header .header-actions .notification-btn{font-size:1.1rem}.dashboard-header .header-actions .profile-avatar{width:28px}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:30}.sidebar-backdrop.is-open{opacity:1;pointer-events:auto}}@media (max-width: 414px){.dashboard-header{padding:.6rem .9rem}.dashboard-header h1{font-size:1.15rem}}@media (max-width: 375px){.dashboard-header{padding:.55rem .85rem}.dashboard-header h1{font-size:1.1rem}.dashboard-header .header-actions{gap:.5rem}}@media (max-width: 320px){.dashboard-header{padding:.5rem .75rem}.dashboard-header h1{font-size:1.05rem}.dashboard-header .menu-toggle{width:34px;height:34px}.dashboard-header .profile-avatar{width:26px}}.detail-tenaga-form{max-width:700px;margin:auto;padding:2rem}.detail-tenaga-form h2{font-size:1.5rem;margin-bottom:.25rem}.detail-tenaga-form .form-header{display:flex;justify-content:space-between;align-items:center}.detail-tenaga-form .btn-edit,.detail-tenaga-form .btn-save{background-color:#1a73e8;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;font-weight:500}.detail-tenaga-form .btn-save{background-color:#34a853}.detail-tenaga-form .subtitle{color:#666;margin-bottom:1.5rem}.detail-tenaga-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.detail-tenaga-form .form-grid .form-group{display:flex;flex-direction:column}.detail-tenaga-form .form-grid .form-group label{font-weight:500;margin-bottom:.5rem}.detail-tenaga-form .form-grid .form-group input{padding:.5rem;border:1px solid #ccc;border-radius:6px;background-color:#f9f9f9}.detail-tenaga-form .form-grid .form-group.full{grid-column:span 2}.detail-tenaga-form .form-grid .logo-upload{display:flex;align-items:center;gap:1rem}.detail-tenaga-form .form-grid .logo-upload .profile-img{width:48px;height:48px;border-radius:8px;object-fit:cover;background-color:#eee}.detail-tenaga-form .form-grid .logo-upload .btn-upload{background-color:#f1f1f1;border:1px solid #ccc;padding:.4rem 1rem;border-radius:6px;cursor:pointer}.detail-tenaga-form .form-group label{font-weight:500;margin-bottom:6px;display:block;color:#333}.detail-tenaga-form .form-group input[readonly]{background-color:#f5f5f5;border:1px solid #ddd;color:#555;cursor:not-allowed}.detail-tenaga-form .form-group select{width:100%;padding:10px;border-radius:6px;border:1px solid #ccc;background-color:#fff;font-size:1rem;transition:border .3s ease}.detail-tenaga-form .form-group select:focus{outline:none;border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e833}.TenagaProfesional-admin{padding:1.5rem;max-width:1400px;margin:0 auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--gray-800)}.TenagaProfesional-admin .page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.TenagaProfesional-admin .page-header h1{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin:0 0 .5rem}.TenagaProfesional-admin .page-header p{color:var(--gray-600);margin:0;font-size:.95rem}.TenagaProfesional-admin .card{background:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);overflow:hidden;margin-bottom:2rem}.TenagaProfesional-admin .card .card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.TenagaProfesional-admin .TenagaProfesional-admin .search-box{position:relative;display:flex;align-items:center;gap:10px;flex:1 1 400px;min-width:280px;max-width:600px}.TenagaProfesional-admin .TenagaProfesional-admin .search-box .search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--gray-500);pointer-events:none}.TenagaProfesional-admin .TenagaProfesional-admin .search-box input[type=text]{flex:1 1 auto;min-width:0;height:44px;width:auto;padding:.6rem 1rem .6rem 2.5rem;border:2px solid var(--gray-400);border-radius:6px;font-size:.9rem;transition:var(--transition);box-sizing:border-box}.TenagaProfesional-admin .TenagaProfesional-admin .search-box input[type=text]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4361ee26}.TenagaProfesional-admin .TenagaProfesional-admin .search-box .btn.btn-primary{flex:0 0 auto;width:auto;min-width:100px;height:44px;padding:0 16px;white-space:nowrap}.TenagaProfesional-admin .table-responsive-tenpro{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:1rem;margin:1rem 0;scrollbar-width:thin;scrollbar-color:var(--gray-400) var(--gray-100)}.TenagaProfesional-admin .table-responsive-tenpro::-webkit-scrollbar{height:8px}.TenagaProfesional-admin .table-responsive-tenpro::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px;margin:0 1rem}.TenagaProfesional-admin .table-responsive-tenpro::-webkit-scrollbar-thumb{background-color:var(--gray-400);border-radius:4px;border:2px solid var(--gray-100)}.TenagaProfesional-admin .table-responsive-tenpro::-webkit-scrollbar-thumb:hover{background-color:var(--gray-500)}@media (max-width: 768px){.TenagaProfesional-admin .table-responsive-tenpro::-webkit-scrollbar{height:10px}.TenagaProfesional-admin .table-responsive-tenpro::-webkit-scrollbar-thumb{min-width:100px}}.TenagaProfesional-admin .tenpro-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.TenagaProfesional-admin .tenpro-table .tenpro-head{background:#f9fafb}.TenagaProfesional-admin .tenpro-table .tenpro-head th{text-align:left;padding:12px 16px;font-weight:600;color:#374151;font-size:13px;border-bottom:1px solid #e5e7eb;border-right:none;border:none}.TenagaProfesional-admin .tenpro-table .tenpro-head th:nth-child(1){padding-left:10px}.TenagaProfesional-admin .tenpro-table .tenpro-head th:nth-child(2){padding-left:28px}.TenagaProfesional-admin .tenpro-table .tenpro-head th:nth-child(3){padding-left:15px}.TenagaProfesional-admin .tenpro-table .tenpro-head th:nth-child(5){padding-left:25px}.TenagaProfesional-admin .tenpro-table .data-tenpro tr{border-bottom:1px solid #f1f1f1;transition:background .2s}.TenagaProfesional-admin .tenpro-table .data-tenpro tr:hover{background:#f9f9fb}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td{padding:12px 16px;vertical-align:middle;color:#374151;border:none}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .spesialis-cell{display:flex;align-items:center;gap:10px}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .spesialis-cell .spesialis-name,.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .spesialis-cell .user-name{font-weight:500;color:#111827;padding-left:0}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .action-buttons{display:flex;align-items:center;gap:8px}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .action-buttons .btn-action{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;border:none;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s ease}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .action-buttons .btn-action svg{font-size:14px}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .action-buttons .btn-action.btn-edit{background:#e0f2fe;color:#0369a1}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .action-buttons .btn-action.btn-edit:hover{background:#bae6fd}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .action-buttons .btn-action.btn-delete{background:#fee2e2;color:#b91c1c}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .action-buttons .btn-action.btn-delete:hover{background:#fecaca}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .action-buttons .btn-action.btn-warning{background:#fef9c3;color:#92400e}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td .action-buttons .btn-action.btn-warning:hover{background:#fde68a}.TenagaProfesional-admin .tenpro-table .data-tenpro tr td:nth-child(2){padding-left:28px}.TenagaProfesional-admin .tenpro-table .data-tenpro tr .no-results{text-align:center;padding:40px;color:#6b7280}.TenagaProfesional-admin .tenpro-table .data-tenpro tr .no-results h3{margin-top:8px;font-size:15px}.TenagaProfesional-admin .action-buttons{display:flex;gap:.5rem}.TenagaProfesional-admin .pagination-tenpro{display:flex;justify-content:center;align-items:center;gap:8px;padding:6px;background:#f1f3f5;border-radius:12px;width:fit-content;margin:1rem auto 0}.TenagaProfesional-admin .pagination-tenpro .page-btn{width:36px;height:36px;border:0;outline:0;border-radius:10px;background:#fff;color:#6b7280;font-weight:700;font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #1018280f;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,color .12s ease}.TenagaProfesional-admin .pagination-tenpro .page-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1018281a}.TenagaProfesional-admin .pagination-tenpro .page-btn:focus-visible{box-shadow:0 0 0 3px #2563eb40}.TenagaProfesional-admin .pagination-tenpro .page-btn.is-active{background:#1f2a44;color:#fff}.TenagaProfesional-admin .pagination-tenpro .page-btn.nav-btn{width:36px;min-width:36px}.TenagaProfesional-admin .pagination-tenpro .page-btn.nav-btn svg{display:block}.TenagaProfesional-admin .pagination-tenpro .page-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:0 2px 6px #1018280a}@media (max-width: 420px){.TenagaProfesional-admin .pagination-tenpro{gap:6px}.TenagaProfesional-admin .pagination-tenpro .page-btn{width:32px;height:32px;border-radius:8px;font-size:13px}}.TenagaProfesional-admin .btn-action{height:32px;padding:0 12px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid transparent;cursor:pointer;transition:var(--transition);font-size:.85rem;font-weight:500;white-space:nowrap}.TenagaProfesional-admin .btn-action svg{width:14px;height:14px;flex-shrink:0}.TenagaProfesional-admin .btn-action:hover{transform:translateY(-1px);box-shadow:0 1px 3px #0000000d}.TenagaProfesional-admin .btn-action.btn-edit{color:var(--primary);background-color:var(--primary-light);border-color:#4361ee33}.TenagaProfesional-admin .btn-action.btn-edit:hover{background-color:#e4eaff}.TenagaProfesional-admin .btn-action.btn-delete{color:var(--danger);background-color:var(--danger-light);border-color:#ef444433}.TenagaProfesional-admin .btn-action.btn-delete:hover{background-color:#fed8d8}@media (max-width: 1024px){.TenagaProfesional-admin .card-header{flex-direction:column;align-items:stretch}}@media (max-width: 768px){.TenagaProfesional-admin{padding:1rem}.TenagaProfesional-admin .action-buttons{flex-direction:column;gap:.5rem}.TenagaProfesional-admin .btn-action{width:100%;justify-content:center}.TenagaProfesional-admin .role-summary{overflow-x:auto;padding-bottom:.5rem;margin:0 -.25rem;padding:0 .25rem .5rem}.TenagaProfesional-admin .role-summary::-webkit-scrollbar{height:4px}.TenagaProfesional-admin .role-summary::-webkit-scrollbar-thumb{background-color:var(--gray-300);border-radius:2px}.TenagaProfesional-admin .role-summary-item{flex-shrink:0}.TenagaProfesional-admin .user-table th,.TenagaProfesional-admin .user-table td{padding:.75rem 1rem}.TenagaProfesional-admin .user-table .user-cell .user-avatar{width:32px;height:32px}.TenagaProfesional-admin .user-table .user-cell .user-name{font-size:.95rem}.TenagaProfesional-admin .user-table .user-cell .user-email{font-size:.8rem}.TenagaProfesional-admin .user-table .role-badge{padding:.25rem .6rem;font-size:.7rem}}@media (max-width: 576px){.TenagaProfesional-admin .modal-content,.TenagaProfesional-admin .confirmation-dialog{margin:.5rem;width:calc(100% - 1rem)}.TenagaProfesional-admin .modal-body{padding:1.25rem}.TenagaProfesional-admin .role-option .role-desc{display:none!important}}.add-tenpro{display:flex;justify-content:flex-end;margin-bottom:1rem;width:100%}.add-tenpro button{background-color:#4a90e2;color:#fff;border:none;padding:.5rem 1.25rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;margin-left:auto;transition:background-color .2s ease,transform .1s ease;display:flex;align-items:center;gap:.5rem}.add-tenpro button:hover{background-color:#3b7cc4;transform:scale(1.02)}.add-tenpro button:active{transform:scale(.98)}.add-tenpro button:focus{outline:none;box-shadow:0 0 0 3px #4a90e24d}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center}.modal-content{background:#fff;padding:2rem;border-radius:8px;min-width:400px}.form-group{margin-bottom:1rem}.form-group label{font-weight:700;display:block;margin-bottom:.5rem}.form-group input{width:100%;padding:.5rem;font-size:1rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem}.modal-actions .btn-cancel{background:#ccc;padding:.5rem 1rem}.modal-actions .btn-submit{background:#0d6efd;color:#fff;padding:.5rem 1rem}.spesialis{padding:1.5rem;max-width:1400px;margin:0 auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--gray-800)}.spesialis .page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.spesialis .page-header h1{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin:0 0 .5rem}.spesialis .page-header p{color:var(--gray-600);margin:0;font-size:.95rem}.spesialis .card{background:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);overflow:hidden;margin-bottom:2rem}.spesialis .card .card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.spesialis .table-responsive-spesialis{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:1rem;margin:1rem 0;scrollbar-width:thin;scrollbar-color:var(--gray-400) var(--gray-100)}.spesialis .table-responsive-spesialis::-webkit-scrollbar{height:8px}.spesialis .table-responsive-spesialis::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px;margin:0 1rem}.spesialis .table-responsive-spesialis::-webkit-scrollbar-thumb{background-color:var(--gray-400);border-radius:4px;border:2px solid var(--gray-100)}.spesialis .table-responsive-spesialis::-webkit-scrollbar-thumb:hover{background-color:var(--gray-500)}@media (max-width: 768px){.spesialis .table-responsive-spesialis::-webkit-scrollbar{height:10px}.spesialis .table-responsive-spesialis::-webkit-scrollbar-thumb{min-width:100px}}.spesialis .spesialis-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.spesialis .spesialis-table .spesialis-head{background:#f9fafb}.spesialis .spesialis-table .spesialis-head th{text-align:left;padding:12px 16px;font-weight:600;color:#374151;font-size:13px;border-bottom:1px solid #e5e7eb;border-right:none;border:none}.spesialis .spesialis-table .spesialis-head th:nth-child(1){padding-left:10px}.spesialis .spesialis-table .spesialis-head th:nth-child(2){padding-left:28px}.spesialis .spesialis-table .spesialis-head th:nth-child(3){padding-left:15px}.spesialis .spesialis-table .spesialis-head th:nth-child(5){padding-left:25px}.spesialis .spesialis-table .data-spesialis tr{border-bottom:1px solid #f1f1f1;transition:background .2s}.spesialis .spesialis-table .data-spesialis tr:hover{background:#f9f9fb}.spesialis .spesialis-table .data-spesialis tr td{padding:12px 16px;vertical-align:middle;color:#374151;border:none}.spesialis .spesialis-table .data-spesialis tr td .spesialis-cell{display:flex;align-items:center;gap:10px}.spesialis .spesialis-table .data-spesialis tr td .spesialis-cell .spesialis-name,.spesialis .spesialis-table .data-spesialis tr td .spesialis-cell .user-name{font-weight:500;color:#111827;padding-left:0}.spesialis .spesialis-table .data-spesialis tr td .action-buttons{display:flex;align-items:center;gap:8px}.spesialis .spesialis-table .data-spesialis tr td .action-buttons .btn-action{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;border:none;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s ease}.spesialis .spesialis-table .data-spesialis tr td .action-buttons .btn-action svg{font-size:14px}.spesialis .spesialis-table .data-spesialis tr td .action-buttons .btn-action.btn-edit{background:#e0f2fe;color:#0369a1}.spesialis .spesialis-table .data-spesialis tr td .action-buttons .btn-action.btn-edit:hover{background:#bae6fd}.spesialis .spesialis-table .data-spesialis tr td .action-buttons .btn-action.btn-delete{background:#fee2e2;color:#b91c1c}.spesialis .spesialis-table .data-spesialis tr td .action-buttons .btn-action.btn-delete:hover{background:#fecaca}.spesialis .spesialis-table .data-spesialis tr td .action-buttons .btn-action.btn-warning{background:#fef9c3;color:#92400e}.spesialis .spesialis-table .data-spesialis tr td .action-buttons .btn-action.btn-warning:hover{background:#fde68a}.spesialis .spesialis-table .data-spesialis tr td:nth-child(2){padding-left:28px}.spesialis .spesialis-table .data-spesialis tr .no-results{text-align:center;padding:40px;color:#6b7280}.spesialis .spesialis-table .data-spesialis tr .no-results h3{margin-top:8px;font-size:15px}.add-spesialis{display:flex;justify-content:flex-end;margin-bottom:1rem;width:100%}.add-spesialis button{background-color:#4a90e2;color:#fff;border:none;padding:.5rem 1.25rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;margin-left:auto;transition:background-color .2s ease,transform .1s ease;display:flex;align-items:center;gap:.5rem}.add-spesialis button:hover{background-color:#3b7cc4;transform:scale(1.02)}.add-spesialis button:active{transform:scale(.98)}.add-spesialis button:focus{outline:none;box-shadow:0 0 0 3px #4a90e24d}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background-color:#fff;border-radius:8px;padding:24px;width:400px;max-width:90%;box-shadow:0 4px 12px #0003;animation:fadeIn .25s ease-in-out}.modal-form .form-group label{margin-bottom:8px;font-weight:500}.modal-form .form-group input{padding:8px 12px;font-size:14px;border:1px solid #ccc;border-radius:4px}.modal-form .form-group input:focus{outline:none;border-color:#4a90e2}.modal-form .modal-actions{display:flex;justify-content:flex-end;gap:12px}.modal-form .modal-actions .btn{padding:8px 16px;font-size:14px;border:none;border-radius:4px;cursor:pointer}.modal-form .modal-actions .btn-secondary:hover{background-color:#cfcfcf}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.modal-backdrop{position:fixed;top:0;left:0;z-index:999;width:100%;height:100%;background-color:#0006;display:flex;justify-content:center;align-items:center}.modal{background-color:#fff;padding:24px;width:400px;max-width:90%;border-radius:8px;box-shadow:0 12px 32px #00000040;animation:fadeIn .25s ease-in-out}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-header h2{font-size:20px;margin:0}.modal-header .close-btn{font-size:20px;background:transparent;border:none;cursor:pointer;color:#333}.modal-header .close-btn:hover{color:red}.modal-form .form-group{display:flex;flex-direction:column;margin-bottom:16px}.modal-form .form-group label{font-weight:600;margin-bottom:6px}.modal-form .form-group input{padding:8px 12px;font-size:14px;border-radius:4px;border:1px solid #ccc;transition:border-color .2s}.modal-form .form-group input:focus{border-color:#4a90e2;outline:none}.modal-form .modal-actions{display:flex;justify-content:flex-end;gap:10px}.modal-form .modal-actions .btn{padding:8px 16px;font-size:14px;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.modal-form .modal-actions .btn-primary{background-color:#4a90e2;color:#fff}.modal-form .modal-actions .btn-primary:hover{background-color:#357ab8}.modal-form .modal-actions .btn-secondary{background-color:#e0e0e0;color:#333}.modal-form .modal-actions .btn-secondary:hover{background-color:#c5c5c5}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.feature-card{padding:24px;background-color:#fffbe6;border:1px solid #ffe58f;border-radius:8px;box-shadow:0 4px 12px #0000000d;text-align:center;max-width:500px;margin:32px auto}.feature-card .feature-title{font-size:18px;font-weight:600;color:#faad14;margin-bottom:8px}.feature-card .feature-description{font-size:14px;color:#595959}:root{--ka-primary: #3b82f6;--ka-primary-600: #2563eb;--ka-danger: #ef4444;--ka-success: #10b981;--ka-warning: #f59e0b;--ka-gray-50: #f9fafb;--ka-gray-100: #f3f4f6;--ka-gray-200: #e5e7eb;--ka-gray-300: #d1d5db;--ka-gray-400: #9ca3af;--ka-gray-500: #6b7280;--ka-gray-600: #4b5563;--ka-gray-700: #374151;--ka-gray-800: #1f2937;--ka-gray-900: #111827;--ka-radius: 12px;--ka-shadow: 0 6px 18px rgba(0, 0, 0, .06);--ka-transition: .2s ease}.konsultasi-admin{padding:1.5rem;color:var(--ka-gray-800)}.konsultasi-admin .header-konsultasi{margin-bottom:1.25rem;border-bottom:1px solid var(--ka-gray-200);padding-bottom:.75rem}.konsultasi-admin .header-konsultasi h1{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:var(--ka-gray-900)}.konsultasi-admin .header-konsultasi p{margin:0;color:var(--ka-gray-500);font-size:.95rem}.konsultasi-admin .card-konsultasi-admin{background:#fff;border-radius:var(--ka-radius);box-shadow:var(--ka-shadow);border:1px solid var(--ka-gray-200);overflow:hidden}.konsultasi-admin .card-konsultasi-admin .header-card{padding:1rem 1.25rem;border-bottom:1px solid var(--ka-gray-200);display:flex;align-items:center;justify-content:space-between;gap:.75rem}.konsultasi-admin .card-konsultasi-admin .header-card .search-box-konsultasi{position:relative;max-width:400px;min-width:280px;flex:1;display:flex}.konsultasi-admin .card-konsultasi-admin .header-card .search-box-konsultasi input{width:100%;padding:.6rem 1rem .6rem 2.5rem;border:2px solid var(--gray-400);border-radius:6px;font-size:.9rem;transition:var(--transition);margin-right:1rem}.konsultasi-admin .card-konsultasi-admin .header-card .search-box-konsultasi input:focus{outline:none;border-color:var(--primary);border-width:2px;box-shadow:0 0 0 3px #4361ee26}.konsultasi-admin .card-konsultasi-admin .header-card .search-box-konsultasi .search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--gray-500);display:flex;align-items:center;justify-content:center}.konsultasi-admin .card-konsultasi-admin .header-card .search-box-konsultasi .btn-role.btn-primary{height:40px;padding:0 10px;white-space:nowrap}.konsultasi-admin .card-konsultasi-admin .header-card .search-box-konsultasi .btn-role.btn-primary:hover{background-color:#2563eb}.konsultasi-admin .card-konsultasi-admin .header-card .search-box-konsultasi .btn-role.btn-primary:active{background-color:#1d4ed8}.konsultasi-admin .card-konsultasi-admin .header-card .search-box-konsultasi .btn-role.btn-primary:disabled{background-color:#a5b4fc;cursor:not-allowed}.konsultasi-admin .card-konsultasi-admin .table-responsive{width:100%;overflow-x:auto;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:1rem}.konsultasi-admin .card-konsultasi-admin .table-konsultasi{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-head{background:#f9fafb}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-head th{text-align:left;padding:12px 16px;font-weight:600;color:#374151;font-size:13px;border-bottom:1px solid #e5e7eb;border-right:none;border:none}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-head th:nth-child(1){padding-left:10px}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-head th:nth-child(2){padding-left:28px}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-head th:nth-child(3){padding-left:40px}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-head th:nth-child(5){padding-left:90px}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr{border-bottom:1px solid #f1f1f1;transition:background .2s}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr:hover{background:#f9f9fb}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td{padding:12px 16px;vertical-align:middle;color:#374151;border:none}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .konsultasi-cell{display:flex;align-items:center;gap:10px}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .konsultasi-cell img{width:34px;height:34px;border-radius:50%;object-fit:cover}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .konsultasi-cell .cell-name{font-weight:500;color:#111827}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .action-buttons{display:flex;align-items:center;gap:8px}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .action-buttons .btn-action{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;border:none;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s ease}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .action-buttons .btn-action svg{font-size:14px}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .action-buttons .btn-action.btn-edit{background:#e0f2fe;color:#0369a1}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .action-buttons .btn-action.btn-edit:hover{background:#bae6fd}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .action-buttons .btn-action.btn-delete{background:#fee2e2;color:#b91c1c}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .action-buttons .btn-action.btn-delete:hover{background:#fecaca}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .action-buttons .btn-action.btn-warning{background:#fef9c3;color:#92400e}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td .action-buttons .btn-action.btn-warning:hover{background:#fde68a}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr td:nth-child(2){padding-left:28px}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr .no-results{text-align:center;padding:40px;color:#6b7280}.konsultasi-admin .card-konsultasi-admin .table-konsultasi .konsultasi-body tr .no-results h3{margin-top:8px;font-size:15px}.konsultasi-admin .card-konsultasi-admin>div{overflow-x:auto;-webkit-overflow-scrolling:touch}.konsultasi-admin .loading-placeholder{width:100%;height:16px;border-radius:6px;background:linear-gradient(90deg,#f3f4f6,#e5e7eb,#f3f4f6);background-size:200% 100%;animation:shimmer 1.2s infinite linear}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.konsultasi-admin .pagination-role{display:flex;justify-content:center;align-items:center;gap:8px;padding:6px;background:#f1f3f5;border-radius:12px;width:fit-content;margin:1rem auto 0}.konsultasi-admin .pagination-role .page-btn{width:36px;height:36px;border:0;outline:0;border-radius:10px;background:#fff;color:#6b7280;font-weight:700;font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #1018280f;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,color .12s ease}.konsultasi-admin .pagination-role .page-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1018281a}.konsultasi-admin .pagination-role .page-btn:focus-visible{box-shadow:0 0 0 3px #2563eb40}.konsultasi-admin .pagination-role .page-btn.is-active{background:#1f2a44;color:#fff}.konsultasi-admin .pagination-role .page-btn.nav-btn{width:36px;min-width:36px}.konsultasi-admin .pagination-role .page-btn.nav-btn svg{display:block}.konsultasi-admin .pagination-role .page-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:0 2px 6px #1018280a}@media (max-width: 420px){.konsultasi-admin .pagination-role{gap:6px}.konsultasi-admin .pagination-role .page-btn{width:32px;height:32px;border-radius:8px;font-size:13px}}@media (min-width: 1600px){.konsultasi-admin{padding:2rem}.konsultasi-admin .header-konsultasi h1{font-size:1.7rem}.konsultasi-admin .card-konsultasi-admin .header-card{padding:1.25rem 1.5rem}.konsultasi-admin .table-konsultasi thead th,.konsultasi-admin .table-konsultasi tbody td{padding:1rem 1.25rem}}@media (min-width: 1280px) and (max-width: 1599px){.konsultasi-admin .table-konsultasi{font-size:.93rem}}@media (min-width: 1024px) and (max-width: 1279px){.konsultasi-admin .card-konsultasi-admin .header-card{flex-wrap:wrap}.konsultasi-admin .card-konsultasi-admin .header-card .search-box{flex:1 1 100%}}@media (min-width: 768px) and (max-width: 1023px){.konsultasi-admin{padding:1rem}.konsultasi-admin .table-konsultasi thead th:first-child{width:70px}.konsultasi-admin .table-konsultasi thead th,.konsultasi-admin .table-konsultasi tbody td{padding:.8rem .9rem}}@media (max-width: 767px){.konsultasi-admin{padding:.9rem}.konsultasi-admin .header-konsultasi h1{font-size:1.25rem}.konsultasi-admin .card-konsultasi-admin .header-card{padding:.9rem}.konsultasi-admin .card-konsultasi-admin .header-card .search-box{flex:1 1 100%}.konsultasi-admin .card-konsultasi-admin .header-card .search-box input{height:38px}.konsultasi-admin .card-konsultasi-admin .header-card .search-box .btn.btn-primary{height:38px;padding:0 14px}.konsultasi-admin .card-konsultasi-admin .table-konsultasi{font-size:.88rem}.konsultasi-admin .card-konsultasi-admin .table-konsultasi thead th,.konsultasi-admin .card-konsultasi-admin .table-konsultasi tbody td{padding:.72rem .8rem}.konsultasi-admin .card-konsultasi-admin .table-konsultasi thead th:first-child{width:56px}.konsultasi-admin .pagination{gap:6px}.konsultasi-admin .pagination button{height:36px;padding:0 12px}.konsultasi-admin .pagination .page-number{height:36px;min-width:36px}}:root{--modal-bg: #fff;--modal-border: rgba(20, 31, 46, .08);--modal-shadow: 0 24px 80px rgba(0, 0, 0, .22);--primary: #151e2d;--text: #182230;--muted: #6b7280;--ring: rgba(21, 30, 45, .3);--radius: 16px;--gap: 14px}.modal-backdrop.modern{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;padding:24px;background:#0a0e136b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .15s ease-out}.modal-card.modern{width:100%;max-width:860px;background:var(--modal-bg);border:1px solid var(--modal-border);border-radius:var(--radius);box-shadow:var(--modal-shadow);overflow:hidden;transform:translateY(8px) scale(.98);animation:popIn .18s ease-out forwards;isolation:isolate}.icon-btn.close{background:transparent;border:0;font-size:24px;line-height:1;cursor:pointer;color:var(--muted);padding:6px 8px;border-radius:10px;transition:background .15s ease,color .15s ease,transform .05s ease}.modal-body.modern{padding:18px 18px 1000px;max-height:min(78vh,860px);overflow:auto;background:#fff}.modal-body.modern h3{margin:0 0 6px;font-size:.95rem;font-weight:700;color:var(--text)}.modal-body.modern>.name,.modal-body.modern>.metode_konsultasi,.modal-body.modern>.tenaga_profesional,.modal-body.modern>.keluhan,.modal-body.modern>.initial_consult,.modal-body.modern>.status_konsultasi{margin-top:14px}.modal-body.modern input,.modal-body.modern select,.modal-body.modern textarea{width:100%;padding:10px 12px;border:1px solid #e6eaf2;border-radius:10px;background:#fff;color:var(--text);transition:border-color .12s ease,box-shadow .12s ease}.modal-body.modern input:focus,.modal-body.modern select:focus,.modal-body.modern textarea:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 3px #151e2d1a}.modal-body.modern textarea{resize:vertical;min-height:96px}.form-grid.modern{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:var(--gap)}.form-grid.modern .col-span-1{grid-column:span 1}.modal-actions.modern{position:sticky;bottom:0;z-index:2;display:flex;gap:10px;justify-content:flex-end;margin:0 -18px;padding:14px 18px calc(14px + env(safe-area-inset-bottom));background-color:#fff;border-top:1px solid var(--modal-border);box-shadow:0 -8px 16px #151e2d0f;-webkit-backdrop-filter:none;backdrop-filter:none}.back{border:1px solid #e6eaf2;border-radius:12px;padding:8px 12px;background:#fff;font-weight:600}.btn.primary:disabled{opacity:.55;cursor:not-allowed}.btn.primary:not(:disabled):hover{filter:brightness(.95)}@media (max-width: 680px){.modal-card.modern{max-width:100%}.modal-body.modern{padding:14px}.modal-actions.modern{padding:12px 14px}}.ac{position:relative}.ac-list{position:absolute;left:0;right:0;top:calc(100% + 6px);background:#fff;border:1px solid #e6eaf2;border-radius:10px;box-shadow:0 12px 32px #0000001f;max-height:240px;overflow:auto;padding:6px;z-index:20}.ac-list li{padding:8px 10px;border-radius:8px;cursor:pointer}.ac-list li.active,.ac-list li:hover{background:#f5f7fb}.ac-list .p{font-weight:600}.ac-list .s{font-size:12px;color:#6b7280}.riwayat-konsultasi{padding:1.5rem;max-width:1400px;margin:0 auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--gray-800)}.riwayat-konsultasi .page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.riwayat-konsultasi .page-header h1{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin:0 0 .5rem}.riwayat-konsultasi .page-header p{color:var(--gray-600);margin:0;font-size:.95rem}.riwayat-konsultasi .card{background:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);overflow:hidden;margin-bottom:2rem}.riwayat-konsultasi .card .card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.riwayat-konsultasi .search-box-user{display:flex;align-items:center;gap:12px;width:100%;max-width:580px;margin:0}.riwayat-konsultasi .search-box-user>input[type=text]{flex:1 1 auto;height:44px;padding:0 14px;border:1.5px solid #e5e7eb;border-radius:12px;background:#fff;font-size:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.riwayat-konsultasi .search-box-user>input[type=text]::placeholder{color:#9ca3af}.riwayat-konsultasi .search-box-user>input[type=text]:hover{border-color:#cbd5e1}.riwayat-konsultasi .search-box-user>input[type=text]:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.riwayat-konsultasi .table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:1rem;margin:1rem 0;scrollbar-width:thin;scrollbar-color:var(--gray-400) var(--gray-100)}.riwayat-konsultasi .table-responsive::-webkit-scrollbar{height:8px}.riwayat-konsultasi .table-responsive::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px;margin:0 1rem}.riwayat-konsultasi .table-responsive::-webkit-scrollbar-thumb{background-color:var(--gray-400);border-radius:4px;border:2px solid var(--gray-100)}.riwayat-konsultasi .table-responsive::-webkit-scrollbar-thumb:hover{background-color:var(--gray-500)}@media (max-width: 768px){.riwayat-konsultasi .table-responsive::-webkit-scrollbar{height:10px}.riwayat-konsultasi .table-responsive::-webkit-scrollbar-thumb{min-width:100px}}.riwayat-konsultasi .riwayatKonsultas-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.9rem;color:var(--gray-700);border:1px solid var(--gray-400);border-radius:8px;overflow:hidden}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsul-head{background:#f9fafb}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsul-head th{text-align:left;padding:12px 16px;font-weight:600;color:#374151;font-size:13px;border-bottom:1px solid #e5e7eb;border-right:none;border:none}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsul-head th:nth-child(1){padding-left:30px}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsul-head th:nth-child(2){padding-left:28px}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsul-head th:nth-child(3){padding-left:25px}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsul-head th:nth-child(4){padding-left:60px}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsul-head th:nth-child(6){padding-left:20px}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr{border-bottom:1px solid #f1f1f1;transition:background .2s}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr:hover{background:#f9f9fb}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td.no{padding-left:35px}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td{padding:12px 16px;vertical-align:middle;color:#374151;border:none}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .user-cell{display:flex;align-items:center;gap:10px}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .user-cell img{width:34px;height:34px;border-radius:50%;object-fit:cover}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .user-cell .user-name{font-weight:500;color:#111827}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .role-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:4px 10px;border-radius:20px}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .role-badge.role-1{background:#dbeafe;color:#1d4ed8}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .role-badge.role-2{background:#46c04c;color:#f1f1f1}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .role-badge.role-3{background:#508acc;color:#edf0ee}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .role-badge.role-4{background:#fd902a;color:#fff}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .role-badge.role-5{background:#f0f0f0;color:#000}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .action-buttons{display:flex;align-items:center;gap:8px}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .action-buttons .btn-action{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;border:none;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s ease}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .action-buttons .btn-action svg{font-size:14px}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .action-buttons .btn-action.btn-edit{background:#e0f2fe;color:#0369a1}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .action-buttons .btn-action.btn-edit:hover{background:#bae6fd}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .action-buttons .btn-action.btn-delete{background:#fee2e2;color:#b91c1c}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .action-buttons .btn-action.btn-delete:hover{background:#fecaca}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .action-buttons .btn-action.btn-warning{background:#fef9c3;color:#92400e}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td .action-buttons .btn-action.btn-warning:hover{background:#fde68a}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr td:nth-child(2){padding-left:28px}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr .no-results{text-align:center;padding:40px;color:#6b7280}.riwayat-konsultasi .riwayatKonsultas-table .dataKonsul tr .no-results h3{margin-top:8px;font-size:15px}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsultas-cell{display:flex;align-items:center;gap:.75rem}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsultas-cell .riwayatKonsultas-avatar{width:36px;height:36px;border-radius:50%;background-color:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsultas-cell .riwayatKonsultas-avatar svg{width:18px;height:18px}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsultas-cell .riwayatKonsultas-name{font-weight:500;color:var(--gray-900);margin-bottom:.15rem}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsultas-cell .riwayatKonsultas-email{font-size:.85rem;color:var(--gray-500)}.riwayat-konsultasi .action-buttons{display:flex;gap:.5rem}.riwayat-konsultasi .btn-action{height:32px;padding:0 12px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid transparent;cursor:pointer;transition:var(--transition);font-size:.85rem;font-weight:500;white-space:nowrap}.riwayat-konsultasi .btn-action svg{width:14px;height:14px;flex-shrink:0}.riwayat-konsultasi .btn-action:hover{transform:translateY(-1px);box-shadow:0 1px 3px #0000000d}.riwayat-konsultasi .btn-action.btn-edit{color:var(--primary);background-color:var(--primary-light);border-color:#4361ee33}.riwayat-konsultasi .btn-action.btn-edit:hover{background-color:#e4eaff}.riwayat-konsultasi .btn-action.btn-delete{color:var(--danger);background-color:var(--danger-light);border-color:#ef444433}.riwayat-konsultasi .btn-action.btn-delete:hover{background-color:#fed8d8}td.status-cell{text-align:center;vertical-align:middle}.badge{display:inline-block;padding:.35rem .75rem;font-size:.8rem;font-weight:600;border-radius:12px;text-transform:capitalize;white-space:nowrap;border:1px solid transparent;margin-left:0}.badge.status-diterima{background-color:var(--info-light);color:var(--info);border-color:#3b82f64d}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;padding:6px;background:#f1f3f5;border-radius:12px;width:fit-content;margin:1rem auto 0}.pagination .page-btn{width:36px;height:36px;border:0;outline:0;border-radius:10px;background:#fff;color:#6b7280;font-weight:700;font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #1018280f;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,color .12s ease}.pagination .page-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1018281a}.pagination .page-btn:focus-visible{box-shadow:0 0 0 3px #2563eb40}.pagination .page-btn.is-active{background:#1f2a44;color:#fff}.pagination .page-btn.nav-btn{width:36px;min-width:36px}.pagination .page-btn.nav-btn svg{display:block}.pagination .page-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:0 2px 6px #1018280a}@media (max-width: 420px){.pagination{gap:6px}.pagination .page-btn{width:32px;height:32px;border-radius:8px;font-size:13px}}@media (min-width: 1600px){.riwayat-konsultasi{max-width:1600px;padding:2rem}.riwayat-konsultasi .page-header h1{font-size:1.9rem}.riwayat-konsultasi .card .card-header{padding:1.5rem 2rem}.riwayat-konsultasi .riwayatKonsultas-table{font-size:.95rem}.riwayat-konsultasi .riwayatKonsultas-table th,.riwayat-konsultasi .riwayatKonsultas-table td{padding:1rem 1.5rem}.riwayat-konsultasi .riwayatKonsultas-table th:first-child,.riwayat-konsultasi .riwayatKonsultas-table td:first-child{width:80px}}@media (min-width: 1280px) and (max-width: 1599px){.riwayat-konsultasi{max-width:1400px}.riwayat-konsultasi .riwayatKonsultas-table th,.riwayat-konsultasi .riwayatKonsultas-table td{padding:.9rem 1.25rem}}@media (min-width: 1024px) and (max-width: 1279px){.riwayat-konsultasi{padding:1.25rem}.riwayat-konsultasi .page-header h1{font-size:1.5rem}.riwayat-konsultasi .card .card-header{gap:.75rem;padding:1rem 1.25rem}.riwayat-konsultasi .search-box{max-width:360px}.riwayat-konsultasi .riwayatKonsultas-table{font-size:.88rem}.riwayat-konsultasi .riwayatKonsultas-table th,.riwayat-konsultasi .riwayatKonsultas-table td{padding:.85rem 1rem}.riwayat-konsultasi .riwayatKonsultas-table th:first-child,.riwayat-konsultasi .riwayatKonsultas-table td:first-child{width:64px}}@media (min-width: 768px) and (max-width: 1023px) and (orientation: portrait){.riwayat-konsultasi{padding:1rem}.riwayat-konsultasi .page-header h1{font-size:1.4rem}.riwayat-konsultasi .card .card-header{flex-direction:column;align-items:stretch;gap:.75rem}.riwayat-konsultasi .search-box{max-width:100%;min-width:100%}.riwayat-konsultasi .riwayatKonsultas-summary{overflow-x:auto;padding-bottom:.5rem;gap:.75rem}.riwayat-konsultasi .riwayatKonsultas-summary .riwayatKonsultas-summary-item{padding:.45rem .85rem}.riwayat-konsultasi .riwayat-konsultasi .card .card-header .search-box{display:flex;flex:1 1 480px;max-width:none;min-width:0}.riwayat-konsultasi .riwayat-konsultasi .card .card-header .search-box input{flex:1 1 auto;width:auto;min-width:0}.riwayat-konsultasi .table-responsive{margin:.75rem 0}.riwayat-konsultasi .riwayatKonsultas-table{font-size:.86rem}.riwayat-konsultasi .riwayatKonsultas-table th,.riwayat-konsultasi .riwayatKonsultas-table td{padding:.75rem .9rem}.riwayat-konsultasi .riwayatKonsultas-table th:first-child,.riwayat-konsultasi .riwayatKonsultas-table td:first-child{width:56px}.riwayat-konsultasi .riwayatKonsultas-table tbody td{height:64px}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsultas-cell{gap:.6rem}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsultas-cell .riwayatKonsultas-avatar{width:32px;height:32px}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsultas-cell .riwayatKonsultas-name{font-size:.95rem}.riwayat-konsultasi .action-buttons{flex-direction:row;flex-wrap:wrap;gap:.4rem}.riwayat-konsultasi .action-buttons .btn-action{padding:0 10px;height:30px;font-size:.82rem}}@media (max-width: 767px){.riwayat-konsultasi{padding:.9rem}.riwayat-konsultasi .page-header{margin-bottom:1.25rem}.riwayat-konsultasi .page-header h1{font-size:1.25rem}.riwayat-konsultasi .page-header p{font-size:.9rem}.riwayat-konsultasi .card{margin-bottom:1.25rem}.riwayat-konsultasi .card .card-header{flex-direction:column;align-items:stretch;gap:.75rem;padding:1rem}.riwayat-konsultasi .riwayatKonsultas-summary{gap:.6rem;overflow-x:auto;padding-bottom:.4rem}.riwayat-konsultasi .riwayatKonsultas-summary .riwayatKonsultas-summary-item{padding:.45rem .75rem;font-size:.82rem}.riwayat-konsultasi .riwayatKonsultas-summary .riwayatKonsultas-summary-item .riwayatKonsultas-badge{width:28px;height:28px}.riwayat-konsultasi .table-responsive{margin:.6rem 0;padding-bottom:.6rem}.riwayat-konsultasi .table-responsive::-webkit-scrollbar{height:10px}.riwayat-konsultasi .table-responsive::-webkit-scrollbar-thumb{min-width:100px}.riwayat-konsultasi .riwayatKonsultas-table{font-size:.84rem;border-radius:6px}.riwayat-konsultasi .riwayatKonsultas-table th,.riwayat-konsultasi .riwayatKonsultas-table td{padding:.7rem .85rem}.riwayat-konsultasi .riwayatKonsultas-table th:first-child,.riwayat-konsultasi .riwayatKonsultas-table td:first-child{width:52px}.riwayat-konsultasi .riwayatKonsultas-table tbody td{height:58px}.riwayat-konsultasi .riwayatKonsultas-table .badge{font-size:.75rem;padding:.3rem .6rem}.riwayat-konsultasi .action-buttons{flex-direction:column;gap:.5rem}.riwayat-konsultasi .action-buttons .btn-action{width:100%;justify-content:center;height:34px;font-size:.84rem}.riwayat-konsultasi .modal-content{width:100%;max-width:520px}.riwayat-konsultasi .card .card-header .search-box{display:flex;max-width:none;min-width:0}.riwayat-konsultasi .card .card-header .search-box input{flex:1 1 auto;width:auto;min-width:0}}@media (max-width: 414px){.riwayat-konsultasi .page-header h1{font-size:1.2rem}.riwayat-konsultasi .riwayatKonsultas-table th,.riwayat-konsultasi .riwayatKonsultas-table td{padding:.65rem .8rem}.riwayat-konsultasi .riwayatKonsultas-table .riwayatKonsultas-cell .riwayatKonsultas-name{font-size:.92rem}}@media (max-width: 375px){.riwayat-konsultasi{padding:.75rem}.riwayat-konsultasi .riwayatKonsultas-table{font-size:.82rem}.riwayat-konsultasi .riwayatKonsultas-table th,.riwayat-konsultasi .riwayatKonsultas-table td{padding:.6rem .75rem}.riwayat-konsultasi .riwayatKonsultas-table th:first-child,.riwayat-konsultasi .riwayatKonsultas-table td:first-child{width:48px}.riwayat-konsultasi .riwayatKonsultas-table .badge{font-size:.72rem;padding:.28rem .55rem}.riwayat-konsultasi .pagination{gap:6px}.riwayat-konsultasi .pagination button{padding:.35rem .6rem;font-size:.85rem}}@media (max-width: 320px){.riwayat-konsultasi{padding:.6rem}.riwayat-konsultasi .page-header h1{font-size:1.1rem}.riwayat-konsultasi .riwayatKonsultas-table{font-size:.8rem}.riwayat-konsultasi .riwayatKonsultas-table th,.riwayat-konsultasi .riwayatKonsultas-table td{padding:.55rem .65rem}.riwayat-konsultasi .riwayatKonsultas-table th:first-child,.riwayat-konsultasi .riwayatKonsultas-table td:first-child{width:44px}.riwayat-konsultasi .action-buttons .btn-action{height:32px;font-size:.8rem}}.jadwal{min-height:100vh;background-color:#f9fafb;padding:2rem}.jadwal .jadwal-container{max-width:960px;margin:0 auto;background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000f;padding:2rem}@media (max-width: 768px){.jadwal .jadwal-container{padding:1.25rem}}.jadwal .jadwal-header{border-bottom:1px solid #e5e7eb;margin-bottom:1.5rem;padding-bottom:1rem}.jadwal .jadwal-header h2{font-size:1.75rem;font-weight:700;color:#1f2937}.jadwal .jadwal-main section h2{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:#374151}.jadwal .jadwal-main section .calendar-wrapper{margin-top:1rem}.time-slot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.time-slot-header .time-slot-title{display:flex;flex-direction:column}.time-slot-header .time-slot-title h3{font-size:1.125rem;font-weight:600;margin:0}.time-slot-header .time-slot-title span{font-size:.875rem;color:#6b7280}.time-slot-header .session-actions{display:flex;gap:.5rem;align-items:center}.time-slot-header .btn-session{background-color:#e5e7eb;color:#111827;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.time-slot-header .btn-session:hover{background-color:#d1d5db}.time-slot-header .btn-session.primary{background-color:#2563eb;color:#fff}.time-slot-header .btn-session.primary:hover{background-color:#1d4ed8}.time-slot-header .btn-session.primary:active{background-color:#1e40af}.time-slot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-top:.75rem}@media (max-width: 480px){.time-slot-grid{grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.5rem}}.time-slot-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;color:#111827;border:1px solid #e5e7eb;border-radius:10px;padding:.65rem .9rem;font-size:.9rem;font-weight:600;line-height:1;text-align:center;cursor:pointer;transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease,background-color .15s ease,color .15s ease;box-shadow:0 2px 6px #0000000a;-webkit-user-select:none;user-select:none}.time-slot-btn:hover{transform:translateY(-1px);border-color:#cbd5e1;box-shadow:0 6px 14px #0000000f}.time-slot-btn:focus-visible{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26,0 6px 14px #0000000f}.time-slot-btn.active{background-color:#2563eb;color:#fff;border-color:#1d4ed8;box-shadow:0 8px 18px #1d4ed840}.time-slot-btn.active:hover{background-color:#1d4ed8;border-color:#1e40af}.time-slot-btn.unavailable,.time-slot-btn:disabled{background-color:#f3f4f6;color:#9ca3af;border-color:#e5e7eb;cursor:not-allowed;text-decoration:line-through;box-shadow:none}.time-slot-btn.unavailable:hover,.time-slot-btn:disabled:hover{transform:none;box-shadow:none}.doctor-unavailable-message{padding:1rem;border:1px dashed #e5e7eb;background-color:#f9fafb;border-radius:10px;color:#6b7280;text-align:center;font-size:.95rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease}.modal-content{background-color:#fff;border-radius:12px;width:100%;max-width:500px;padding:2rem;box-shadow:0 8px 24px #0003;animation:slideUp .3s ease}.modal-content h2{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:#111827}.modal-content .form-group{margin-bottom:1rem}.modal-content .form-group label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.modal-content .form-group input,.modal-content .form-group select{width:100%;padding:.6rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;color:#111827}.modal-content .form-group input:focus,.modal-content .form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.modal-content .modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.modal-content .modal-actions .btn-cancel{background-color:#f3f4f6;color:#374151;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;cursor:pointer}.modal-content .modal-actions .btn-cancel:hover{background-color:#e5e7eb}.modal-content .modal-actions .btn-submit{background-color:#2563eb;color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;cursor:pointer}.modal-content .modal-actions .btn-submit:hover{background-color:#1d4ed8}.modal-content .modal-actions .btn-submit:active{background-color:#1e40af}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;display:grid;place-items:center;z-index:50}.modal-card-editJadwal{width:100%;max-width:520px;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001f;overflow:hidden}.modal-header,.modal-footer{padding:16px 20px;border-bottom:1px solid #eef0f3}.modal-footer{border-top:1px solid #eef0f3;border-bottom:0;display:flex;justify-content:flex-end;gap:8px}.modal-header h3{margin:0;font-size:18px;font-weight:700}.modal-close{background:transparent;border:0;font-size:22px;cursor:pointer}.modal-body{padding:16px 20px;display:grid;gap:12px}.form-row{display:grid;gap:6px}.form-row input,.form-row select{height:40px;border:1px solid #e5e7eb;border-radius:8px;padding:0 12px}.form-error{color:#b91c1c;font-size:13px;margin-top:6px}.btn-session{background-color:#e5e7eb;color:#111827;border:none;border-radius:8px;padding:8px 12px;font-weight:500;cursor:pointer}.btn-session.primary{background-color:#2563eb;color:#fff}.btn-session.primary:disabled{opacity:.6;cursor:not-allowed}.daftar-konsultasi{padding:1.5rem;max-width:1400px;margin:0 auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--gray-800)}.daftar-konsultasi .page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.daftar-konsultasi .page-header h1{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin:0 0 .5rem}.daftar-konsultasi .page-header p{color:var(--gray-600);margin:0;font-size:.95rem}.daftar-konsultasi .card{background:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);overflow:hidden;margin-bottom:2rem}.daftar-konsultasi .card .card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.daftar-konsultasi .search-box-medic{display:flex;align-items:center;gap:12px;width:100%;max-width:580px;margin:0}.daftar-konsultasi .search-box-medic>input[type=text]{flex:1 1 auto;height:44px;padding:0 14px;border:1.5px solid #e5e7eb;border-radius:12px;background:#fff;font-size:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.daftar-konsultasi .search-box-medic>input[type=text]::placeholder{color:#9ca3af}.daftar-konsultasi .search-box-medic>input[type=text]:hover{border-color:#cbd5e1}.daftar-konsultasi .search-box-medic>input[type=text]:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.daftar-konsultasi .search-box-medic>.btn-medic{height:44px;padding:0 24px;border-radius:12px;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.daftar-konsultasi .search-box-medic>.btn-medic.btn-primary{background:#2563eb;color:#fff;border:none}.daftar-konsultasi .search-box-medic>.btn-medic.btn-primary:hover{background:#1d4ed8}.daftar-konsultasi .search-box-medic>.btn-medic.btn-primary:active{transform:translateY(1px)}.daftar-konsultasi .search-box-medic>.btn-medic.btn-primary:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 640px){.daftar-konsultasi .search-box-medic{flex-direction:column;align-items:stretch;gap:8px;max-width:100%}.daftar-konsultasi .search-box-medic>.btn-medic{width:100%}}.daftar-konsultasi .riwayatKonsultas-summary{display:flex;gap:1rem;flex-wrap:wrap}.daftar-konsultasi .riwayatKonsultas-summary .riwayatKonsultas-summary-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem .5rem .75rem;background:var(--gray-100);border-radius:20px;font-size:.85rem;transition:var(--transition)}.daftar-konsultasi .riwayatKonsultas-summary .riwayatKonsultas-summary-item:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.daftar-konsultasi .riwayatKonsultas-summary .riwayatKonsultas-summary-item .riwayatKonsultas-badge{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:600}.daftar-konsultasi .riwayatKonsultas-summary .riwayatKonsultas-summary-item .riwayatKonsultas-badge[class*=role-]{color:#fff;box-shadow:0 2px 4px #0000001a}.daftar-konsultasi .riwayatKonsultas-summary .riwayatKonsultas-summary-item .riwayatKonsultas-badge svg{width:16px;height:16px}.daftar-konsultasi .riwayatKonsultas-summary .riwayatKonsultas-summary-item .role-count{font-weight:600;color:var(--gray-800)}.daftar-konsultasi .riwayatKonsultas-summary .riwayatKonsultas-summary-item .role-label{color:var(--gray-600);white-space:nowrap}.daftar-konsultasi .table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:1rem;margin:1rem 0;scrollbar-width:thin;scrollbar-color:var(--gray-400) var(--gray-100)}.daftar-konsultasi .table-responsive::-webkit-scrollbar{height:8px}.daftar-konsultasi .table-responsive::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px;margin:0 1rem}.daftar-konsultasi .table-responsive::-webkit-scrollbar-thumb{background-color:var(--gray-400);border-radius:4px;border:2px solid var(--gray-100)}.daftar-konsultasi .table-responsive::-webkit-scrollbar-thumb:hover{background-color:var(--gray-500)}@media (max-width: 768px){.daftar-konsultasi .table-responsive::-webkit-scrollbar{height:10px}.daftar-konsultasi .table-responsive::-webkit-scrollbar-thumb{min-width:100px}}.daftar-konsultasi .table-responsive{width:100%;overflow-x:auto;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:1rem}.daftar-konsultasi .table-konsultasi{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.daftar-konsultasi .table-konsultasi .tabel-konsultasi-head{background:#f9fafb}.daftar-konsultasi .table-konsultasi .tabel-konsultasi-head th{text-align:left;padding:12px 16px;font-weight:600;color:#374151;font-size:13px;border-bottom:1px solid #e5e7eb;border-right:none;border:none}.daftar-konsultasi .table-konsultasi .tabel-konsultasi-head th:nth-child(1){padding-left:10px}.daftar-konsultasi .table-konsultasi .tabel-konsultasi-head th:nth-child(2){padding-left:28px}.daftar-konsultasi .table-konsultasi .tabel-konsultasi-head th:nth-child(3){padding-left:15px}.daftar-konsultasi .table-konsultasi .tabel-konsultasi-head th:nth-child(4){padding-left:160px}.daftar-konsultasi .table-konsultasi .tabel-konsultasi-head th:nth-child(6){padding-left:35px}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr{border-bottom:1px solid #f1f1f1;transition:background .2s}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr:hover{background:#f9f9fb}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td.no{padding-left:35px}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td{padding:12px 16px;vertical-align:middle;color:#374151;border:none}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .user-cell{display:flex;align-items:center;gap:10px}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .user-cell img{width:34px;height:34px;border-radius:50%;object-fit:cover}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .user-cell .user-name{font-weight:500;color:#111827}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .role-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:4px 10px;border-radius:20px}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .role-badge.role-1{background:#dbeafe;color:#1d4ed8}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .role-badge.role-2{background:#46c04c;color:#f1f1f1}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .role-badge.role-3{background:#508acc;color:#edf0ee}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .role-badge.role-4{background:#fd902a;color:#fff}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .role-badge.role-5{background:#f0f0f0;color:#000}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .action-buttons{display:flex;align-items:center;gap:8px}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .action-buttons .btn-action{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;border:none;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s ease}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .action-buttons .btn-action svg{font-size:14px}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .action-buttons .btn-action.btn-edit{background:#e0f2fe;color:#0369a1}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .action-buttons .btn-action.btn-edit:hover{background:#bae6fd}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .action-buttons .btn-action.btn-delete{background:#fee2e2;color:#b91c1c}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .action-buttons .btn-action.btn-delete:hover{background:#fecaca}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .action-buttons .btn-action.btn-warning{background:#fef9c3;color:#92400e}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td .action-buttons .btn-action.btn-warning:hover{background:#fde68a}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr td:nth-child(2){padding-left:28px}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr .no-results{text-align:center;padding:40px;color:#6b7280}.daftar-konsultasi .table-konsultasi .tabel-data-konsultasi tr .no-results h3{margin-top:8px;font-size:15px}.daftar-konsultasi .table-konsultasi td.status-cell{text-align:center;vertical-align:middle}.daftar-konsultasi .riwayatKonsultas-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:capitalize;width:fit-content;white-space:nowrap;border:1px solid transparent}.daftar-konsultasi .riwayatKonsultas-badge svg{width:14px;height:14px}.daftar-konsultasi .riwayatKonsultas-badge.role-admin{background-color:#4361ee26;color:#2d4ed8;border-color:#4361ee33}.daftar-konsultasi .riwayatKonsultas-badge.role-admin svg{color:#2d4ed8}.daftar-konsultasi .riwayatKonsultas-badge.role-dokter{background-color:#10b98126;color:#0d9c6b;border-color:#10b98133}.daftar-konsultasi .riwayatKonsultas-badge.role-dokter svg{color:#0d9c6b}.daftar-konsultasi .riwayatKonsultas-badge.role-psikolog{background-color:#8b5cf626;color:#7c3aed;border-color:#8b5cf633}.daftar-konsultasi .riwayatKonsultas-badge.role-psikolog svg{color:#7c3aed}.daftar-konsultasi .riwayatKonsultas-badge.role-karyawan{background-color:#f59e0b26;color:#d97706;border-color:#f59e0b33}.daftar-konsultasi .riwayatKonsultas-badge.role-karyawan svg{color:#d97706}.daftar-konsultasi .riwayatKonsultas-badge.role-user{background-color:#6b72801f;color:#4b5563;border-color:#6b728026}.daftar-konsultasi .riwayatKonsultas-badge.role-user svg{color:#4b5563}.daftar-konsultasi .action-buttons{display:flex;gap:.5rem}.daftar-konsultasi .btn-action{height:32px;padding:0 12px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid transparent;cursor:pointer;transition:var(--transition);font-size:.85rem;font-weight:500;white-space:nowrap}.daftar-konsultasi .btn-action svg{width:14px;height:14px;flex-shrink:0}.daftar-konsultasi .btn-action:hover{transform:translateY(-1px);box-shadow:0 1px 3px #0000000d}.daftar-konsultasi .btn-action.btn-edit{color:var(--primary);background-color:var(--primary-light);border-color:#4361ee33}.daftar-konsultasi .btn-action.btn-edit:hover{background-color:#e4eaff}.daftar-konsultasi .btn-action.btn-delete{color:var(--danger);background-color:var(--danger-light);border-color:#ef444433}.daftar-konsultasi .btn-action.btn-delete:hover{background-color:#fed8d8}.daftar-konsultasi .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease-out}.daftar-konsultasi .modal-content{background:#fff;border-radius:var(--border-radius);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 25px #0000001a;animation:slideUp .3s ease-out}.daftar-konsultasi .modal-content .modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between}.daftar-konsultasi .modal-content .modal-header h3{margin:0;font-size:1.25rem;color:var(--gray-900)}.daftar-konsultasi .modal-content .modal-header .close-btn{background:none;border:none;color:var(--gray-500);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center}.daftar-konsultasi .modal-content .modal-header .close-btn:hover{background-color:var(--gray-100);color:var(--gray-700)}.daftar-konsultasi .modal-content .modal-body{padding:1.5rem}.daftar-konsultasi .modal-content .modal-body .user-info{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--gray-200)}.daftar-konsultasi .modal-content .modal-body .user-info .user-avatar{width:48px;height:48px;border-radius:50%;background-color:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.daftar-konsultasi .modal-content .modal-body .user-info .user-avatar svg{width:24px;height:24px}.daftar-konsultasi .modal-content .modal-body .user-info h4{margin:0 0 .25rem;font-size:1.1rem;color:var(--gray-900)}.daftar-konsultasi .modal-content .modal-body .user-info .current-role{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500}.daftar-konsultasi .modal-content .modal-body .user-info .current-role svg{width:14px;height:14px}.daftar-konsultasi .modal-content .modal-body .form-group{margin-bottom:0}.daftar-konsultasi .modal-content .modal-body .form-group label{display:block;margin-bottom:.75rem;font-weight:500;color:var(--gray-800);font-size:.9rem}.daftar-konsultasi .modal-content .modal-body .role-options{display:flex;flex-direction:column;gap:.25rem}.daftar-konsultasi .modal-content .modal-body .role-options .role-option{display:flex;align-items:center;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease;position:relative}.daftar-konsultasi .modal-content .modal-body .role-options .role-option:hover{border-color:var(--primary-light);background-color:var(--bg-light)}.daftar-konsultasi .modal-content .modal-body .role-options .role-option.selected{border-color:var(--primary);background-color:var(--primary-light)}.daftar-konsultasi .modal-content .modal-body .role-options .role-option .role-icon{margin-right:1rem;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;background-color:var(--bg-light);color:var(--text-color);font-size:1.25rem}.daftar-konsultasi .modal-content .modal-body .role-options .role-option .role-icon svg{width:20px;height:20px}.daftar-konsultasi .modal-content .modal-body .role-options .role-option .role-details{flex:1;display:flex;flex-direction:column}.daftar-konsultasi .modal-content .modal-body .role-options .role-option .role-details .role-name{font-weight:600;color:var(--text-color);margin-bottom:.25rem}.daftar-konsultasi .modal-content .modal-body .role-options .role-option .role-details .role-desc{font-size:.8rem;color:var(--text-muted)}.daftar-konsultasi .modal-content .modal-body .role-options .role-option .selected-indicator{margin-left:1rem;color:var(--primary);font-size:1.25rem}.daftar-konsultasi .modal-content .modal-footer{padding:1.25rem 1.5rem;border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;gap:.75rem}.daftar-konsultasi .modal-content .modal-footer .btn{padding:.5rem 1.25rem;border-radius:6px;font-weight:500;font-size:.9rem;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:.5rem}.daftar-konsultasi .modal-content .modal-footer .btn-outline{background:#fff;border:1px solid var(--gray-300);color:var(--gray-700)}.daftar-konsultasi .modal-content .modal-footer .btn-outline:hover{background-color:var(--gray-100);border-color:var(--gray-400)}.daftar-konsultasi .modal-content .modal-footer .btn-primary{background-color:var(--primary);color:#fff;border:1px solid var(--primary)}.daftar-konsultasi .modal-content .modal-footer .btn-primary:hover{background-color:#2c4dec;border-color:#2c4dec}.daftar-konsultasi .modal-content .modal-footer .btn-primary:disabled{opacity:.6;cursor:not-allowed;background-color:var(--primary)}.daftar-konsultasi .modal-content .modal-footer .btn-danger{background-color:var(--danger);color:#fff;border:1px solid var(--danger)}.daftar-konsultasi .modal-content .modal-footer .btn-danger:hover{background-color:#ed2d2d;border-color:#ed2d2d}.daftar-konsultasi .confirmation-dialog{background:#fff;border-radius:12px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 10px 25px #00000026;animation:slideUp .3s ease-out;border:1px solid var(--gray-200);position:relative}.daftar-konsultasi .confirmation-header{padding:1.5rem;border-bottom:1px solid var(--gray-100);display:flex;align-items:flex-start;gap:1rem;background-color:#fff9f9}.daftar-konsultasi .confirmation-header .icon-wrapper{width:44px;height:44px;border-radius:50%;background-color:#ef44441a;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.daftar-konsultasi .confirmation-header .icon-wrapper .text-danger{color:var(--danger);font-size:1.5rem;width:24px;height:24px}.daftar-konsultasi .confirmation-header h3{margin:0 0 .25rem;font-size:1.25rem;color:var(--gray-900);font-weight:600;line-height:1.3}.daftar-konsultasi .confirmation-header .header-content{flex:1}.daftar-konsultasi .confirmation-header .header-content p.text-muted{margin:0;font-size:.9rem;color:var(--gray-500)}.daftar-konsultasi .confirmation-body{padding:1.5rem;border-bottom:1px solid var(--gray-100)}.daftar-konsultasi .confirmation-body p{margin:0 0 .5rem;color:var(--gray-700);line-height:1.6;font-size:.95rem}.daftar-konsultasi .confirmation-body p strong{color:var(--gray-900);font-weight:600}.daftar-konsultasi .confirmation-body p.text-muted{color:var(--gray-600);font-size:.9rem;margin:1rem 0 0;line-height:1.5}.daftar-konsultasi .confirmation-footer{padding:1.25rem 1.5rem;display:flex;justify-content:flex-end;gap:.75rem;background-color:#f9fafb;border-radius:0 0 12px 12px}.daftar-konsultasi .confirmation-footer .btn{padding:.6rem 1.25rem;border-radius:6px;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-width:100px;border:1px solid transparent}.daftar-konsultasi .confirmation-footer .btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.daftar-konsultasi .confirmation-footer .btn:active{transform:translateY(0)}.daftar-konsultasi .confirmation-footer .btn-outline{background:#fff;border:2px solid var(--gray-400);color:var(--gray-700);font-weight:500}.daftar-konsultasi .confirmation-footer .btn-outline:hover{background-color:var(--gray-50);border-color:var(--gray-500);color:var(--gray-800)}.daftar-konsultasi .confirmation-footer .btn-danger{background-color:var(--danger);color:#fff;border-color:var(--danger)}.daftar-konsultasi .confirmation-footer .btn-danger:hover{background-color:#dc2626;border-color:#dc2626}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1024px){.daftar-konsultasi .card-header{flex-direction:column;align-items:stretch}.daftar-konsultasi .search-box{max-width:100%}}@media (max-width: 768px){.daftar-konsultasi{padding:1rem}.daftar-konsultasi .action-buttons{flex-direction:column;gap:.5rem}.daftar-konsultasi .btn-action{width:100%;justify-content:center}.daftar-konsultasi .role-summary{overflow-x:auto;padding-bottom:.5rem;margin:0 -.25rem;padding:0 .25rem .5rem}.daftar-konsultasi .role-summary::-webkit-scrollbar{height:4px}.daftar-konsultasi .role-summary::-webkit-scrollbar-thumb{background-color:var(--gray-300);border-radius:2px}.daftar-konsultasi .role-summary-item{flex-shrink:0}.daftar-konsultasi .user-table th,.daftar-konsultasi .user-table td{padding:.75rem 1rem}.daftar-konsultasi .user-table .user-cell .user-avatar{width:32px;height:32px}.daftar-konsultasi .user-table .user-cell .user-name{font-size:.95rem}.daftar-konsultasi .user-table .user-cell .user-email{font-size:.8rem}.daftar-konsultasi .user-table .role-badge{padding:.25rem .6rem;font-size:.7rem}}@media (max-width: 576px){.daftar-konsultasi .modal-content,.daftar-konsultasi .confirmation-dialog{margin:.5rem;width:calc(100% - 1rem)}.daftar-konsultasi .modal-body{padding:1.25rem}.daftar-konsultasi .role-option .role-desc{display:none!important}}.modal-tabs{display:flex;border-bottom:1px solid #ddd;margin-bottom:16px}.modal-tab{flex:1;padding:12px;text-align:center;cursor:pointer;background:none;border:none;font-weight:500;border-bottom:2px solid transparent;transition:.2s ease-in-out}.modal-tab.active{border-bottom:2px solid #007bff;color:#007bff}.user-detail-form form{display:flex;flex-direction:column;gap:16px}.user-detail-form form .form-group{display:flex;flex-direction:column}.user-detail-form form .form-group label{font-weight:500;margin-bottom:6px}.user-detail-form form .form-group input,.user-detail-form form .form-group select{padding:10px;border-radius:6px;border:1px solid #ccc;font-size:14px}.add-users{display:flex;justify-content:flex-end;margin-bottom:1rem}.add-users button{background-color:#4a90e2;color:#fff;border:none;padding:.5rem 1.25rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background-color .2s ease,transform .1s ease;display:flex;align-items:center;gap:.5rem}.add-users button:hover{background-color:#3b7cc4;transform:scale(1.02)}.add-users button:active{transform:scale(.98)}.add-users button:focus{outline:none;box-shadow:0 0 0 3px #4a90e24d}.pagination{display:flex;justify-content:center;gap:8px;margin-top:1.5rem}.pagination button{padding:.4rem .75rem;border:none;background-color:#e0e0e0;color:#333;border-radius:6px;font-weight:600;cursor:pointer;transition:.2s ease}.pagination button:hover{background-color:#d0d0d0}.pagination button.active{background-color:#007bff;color:#fff}.search-box{display:flex;align-items:center;gap:12px}.search-box input[type=text]{padding:8px 14px;border:1px solid #ccc;border-radius:8px;outline:none;font-size:14px;flex:1}.search-box input[type=text]:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.search-box .btn.btn-primary{padding:8px 20px;background-color:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color .3s}.search-box .btn.btn-primary:hover{background-color:#2563eb}.search-box .btn.btn-primary:active{background-color:#1d4ed8}.search-box .btn.btn-primary:disabled{background-color:#a5b4fc;cursor:not-allowed}.badge{display:inline-block;padding:.35rem .75rem;font-size:.8rem;font-weight:600;border-radius:12px;text-transform:capitalize;white-space:nowrap;border:1px solid transparent}.badge.status-diajukan{background-color:var(--warning-light);color:var(--warning);border-color:#f59e0b4d}.badge.status-disetujui{background-color:var(--info-light);color:var(--info);border-color:#3b82f64d}.badge.status-ditolak{background-color:var(--danger-light);color:var(--danger);border-color:#ef44444d}.badge.status-selesai{background-color:var(--success-light);color:var(--success);border-color:#10b9814d}.page-btn{width:78px;height:30px}.detail-konsultasi{padding:2rem}.detail-konsultasi .section{margin-bottom:2rem}.detail-konsultasi .section .section-title{font-size:22px;font-weight:700;color:#111518;margin-bottom:1rem}.detail-konsultasi .section .grid-two{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.detail-konsultasi .section .field{border-top:1px solid #dbe1e6;padding-top:1rem}.detail-konsultasi .section .field .label{color:#617989;font-size:.875rem}.detail-konsultasi .section .field .value{color:#111518;font-size:.875rem}.detail-konsultasi .section .history-grid{display:grid;grid-template-columns:20% 1fr;column-gap:1.5rem}.detail-konsultasi .section .history-grid .history-item{grid-column:span 2;border-top:1px solid #dbe1e6;padding-top:1.25rem}.detail-konsultasi .section .history-grid .history-item .label{color:#617989;font-size:.875rem}.detail-konsultasi .section .history-grid .history-item .value{color:#111518;font-size:.875rem}.detail-konsultasi .section .notes{padding:1rem 0;color:#111518;font-size:1rem}:root{--dkm-radius: 14px;--dkm-border: #e5e7eb;--dkm-bg: #ffffff;--dkm-head: #0f172a;--dkm-text: #111827;--dkm-muted: #6b7280;--dkm-soft: #f8fafc;--dkm-shadow: 0 24px 60px rgba(2, 6, 23, .25);--dkm-brand: #2563eb;--dkm-brand-600: #1d4ed8}.dkm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:20px;z-index:1000}.dkm{width:100%;max-width:640px;background:var(--dkm-bg);border:1px solid var(--dkm-border);border-radius:var(--dkm-radius);box-shadow:var(--dkm-shadow);overflow:hidden;animation:dkm-in .18s ease-out}@keyframes dkm-in{0%{transform:translateY(6px);opacity:0}to{transform:translateY(0);opacity:1}}.dkm__header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--dkm-border);background:linear-gradient(180deg,#fff,#fcfcff)}.dkm__header h2{margin:0;font-size:18px;font-weight:700;color:var(--dkm-head)}.dkm__close{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--dkm-border);background:#fff;border-radius:10px;width:34px;height:34px;line-height:1;font-size:20px;cursor:pointer;color:var(--dkm-muted);display:grid;place-items:center;transition:background-color .15s ease,transform .1s ease}.dkm__close:hover{background:var(--dkm-soft)}.dkm__close:active{transform:translateY(1px)}.dkm__body{padding:18px;display:grid;gap:16px}.dkm__field{display:grid;gap:8px}.dkm__label{font-size:14px;font-weight:600;color:var(--dkm-text)}.dkm__textarea,.dkm__select{width:100%;border:1px solid var(--dkm-border);border-radius:12px;padding:10px 12px;font-size:14px;color:var(--dkm-text);background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.dkm__textarea:focus,.dkm__select:focus{outline:none;border-color:var(--dkm-brand);box-shadow:0 0 0 3px #2563eb26}.dkm__textarea{resize:vertical;min-height:120px}.dkm__select-wrap{position:relative}.dkm__select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:38px}.dkm__caret{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:7px solid var(--dkm-muted)}.dkm__footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 18px 18px;background:#fff;border-top:1px solid var(--dkm-border)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .1s ease,box-shadow .15s ease,background-color .15s ease,border-color .15s ease}.btn:focus-visible{outline:3px solid rgba(37,99,235,.25);outline-offset:2px}.btn--primary{color:#fff;border:1px solid var(--dkm-brand-600);background:linear-gradient(180deg,#3b82f6,var(--dkm-brand));box-shadow:0 5px 18px #2563eb47}.btn--primary:hover{background:linear-gradient(180deg,var(--dkm-brand),var(--dkm-brand-600))}.btn--outline{color:var(--dkm-text);background:#fff;border:1px solid var(--dkm-border)}.btn--outline:hover{background:var(--dkm-soft)}@media (max-width: 520px){.dkm{max-width:96vw}.dkm__footer{justify-content:stretch}.btn{width:100%}}.error-text{color:red;font-size:.85rem;margin-top:4px}:root{--radius: 12px;--shadow-sm: 0 4px 14px rgba(2, 6, 23, .06);--shadow-md: 0 8px 22px rgba(2, 6, 23, .1);--brand: #2563eb;--brand-600: #1d4ed8;--brand-700: #1e40af;--text: #0f172a;--muted: #64748b;--border: #e5e7eb;--bg: #ffffff;--bg-soft: #f8fafc}.btn,.btn-update,.btn-back,.btn-status{--bg-btn: var(--bg);--fg-btn: var(--text);--bd-btn: var(--border);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border-radius:var(--radius);border:1px solid var(--bd-btn);background:var(--bg-btn);color:var(--fg-btn);font-size:14px;font-weight:600;line-height:1;cursor:pointer;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-sm);transition:transform .12s ease,box-shadow .16s ease,background-color .16s ease,border-color .16s ease,color .16s ease}.btn:hover,.btn-update:hover,.btn-back:hover,.btn-status:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn:active,.btn-update:active,.btn-back:active,.btn-status:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn:focus-visible,.btn-update:focus-visible,.btn-back:focus-visible,.btn-status:focus-visible{outline:3px solid rgba(37,99,235,.35);outline-offset:2px}.btn:disabled,.btn-update:disabled,.btn-back:disabled,.btn-status:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn.btn--primary,.btn-update,.btn--primary.btn-back,.btn--primary.btn-status{--bg-btn: linear-gradient(180deg, #3b82f6, #2563eb);--fg-btn: #fff;--bd-btn: #1d4ed8}.btn.btn--primary:hover,.btn-update:hover,.btn--primary.btn-back:hover,.btn--primary.btn-status:hover{--bg-btn: linear-gradient(180deg, #2563eb, #1d4ed8)}.btn.btn--primary:active,.btn-update:active,.btn--primary.btn-back:active,.btn--primary.btn-status:active{--bg-btn: #1e40af}.btn.btn--outline,.btn--outline.btn-update,.btn-back,.btn-status{--bg-btn: #ffffff;--fg-btn: var(--text);--bd-btn: #cbd5e1}.btn.btn--outline:hover,.btn--outline.btn-update:hover,.btn-back:hover,.btn-status:hover{--bg-btn: var(--bg-soft)}.btn.btn--subtle,.btn--subtle.btn-update,.btn--subtle.btn-back,.btn--subtle.btn-status{--bg-btn: #edf2ff;--fg-btn: #1e3a8a;--bd-btn: #dbeafe}.btn.btn--subtle:hover,.btn--subtle.btn-update:hover,.btn--subtle.btn-back:hover,.btn--subtle.btn-status:hover{--bg-btn: #e0e7ff}.btn.btn--ghost,.btn--ghost.btn-update,.btn--ghost.btn-back,.btn--ghost.btn-status{--bg-btn: transparent;--bd-btn: transparent}.btn.btn--ghost:hover,.btn--ghost.btn-update:hover,.btn--ghost.btn-back:hover,.btn--ghost.btn-status:hover{--bg-btn: var(--bg-soft)}.btn.btn--sm,.btn--sm.btn-update,.btn--sm.btn-back,.btn--sm.btn-status{padding:8px 12px;font-size:13px}.btn.btn--lg,.btn--lg.btn-update,.btn--lg.btn-back,.btn--lg.btn-status{padding:12px 18px;font-size:15px}.btn.btn--full,.btn--full.btn-update,.btn--full.btn-back,.btn--full.btn-status{width:100%}.back-button-container{display:flex;gap:12px;align-items:center;margin-top:16px}.button-status{padding:1rem 0 .5rem;display:flex;flex-direction:column;align-items:flex-start;gap:8px}.button-status .label{font-size:.9rem;font-weight:700;color:#111827}.chat-section{max-width:70%;margin:0 auto 0 0}.chat-section .chat-box{border:1px solid #e6e6e6;border-radius:16px;padding:12px;max-height:200px;overflow-y:auto;background:#fafafa}.chat-section .chat-empty{text-align:center;color:#9aa0a6;font-size:14px;padding:12px 0}.chat-section .message-row{display:flex;margin:8px 0}.chat-section .message-row.me{justify-content:flex-end}.chat-section .message-row.me .bubble{background:#151e2d;color:#fff;border-top-right-radius:4px;border-top-left-radius:16px}.chat-section .message-row.them{justify-content:flex-start}.chat-section .message-row.them .bubble{background:#fff;color:#222;border:1px solid #e6e6e6;border-top-left-radius:4px;border-top-right-radius:16px}.chat-section .bubble{max-width:75%;padding:10px 12px;border-radius:16px;box-shadow:0 1px 1px #0000000a}.chat-section .bubble-meta{display:flex;align-items:center;gap:6px;font-size:12px;opacity:.7;margin-bottom:4px}.chat-section .bubble-meta .dot{opacity:.6}.chat-section .bubble-text{white-space:pre-wrap;word-break:break-word;font-size:14px;line-height:1.35}.chat-section .chat-input-row{margin-top:10px;display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end}.chat-section .chat-input{width:100%;border:1px solid #e6e6e6;border-radius:12px;padding:10px 12px;font-size:14px;resize:vertical;min-height:44px}.btn-send{height:44px;padding:0 16px;border:none;border-radius:12px;background:#151e2d;color:#fff;font-weight:600;cursor:pointer}.btn-send:disabled{opacity:.5;cursor:not-allowed}.btn-status{position:relative;padding-right:38px}.btn-status:after{content:"";position:absolute;right:12px;top:50%;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--muted);transform:translateY(-50%);pointer-events:none}.btn-status .value{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--text)}.btn-status .value:before{content:"";width:8px;height:8px;border-radius:999px;background:var(--muted)}.btn-status.is-submitted .value:before{background:#3b82f6}.btn-status.is-waiting .value:before{background:#f59e0b}.btn-status.is-approved .value:before{background:#10b981}.btn-status.is-rejected .value:before{background:#ef4444}.jadwal{background:linear-gradient(to right,#f3eaff,#f6f1fe);color:#050505;min-height:100vh}.jadwal .calendar-container{padding:32px 24px}.jadwal .calendar-container .calendar-title{margin-bottom:20px}.jadwal .calendar-container .calendar-title h1{font-size:24px;font-weight:700;color:#020202}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background:#f7f8fb;color:#0f172a;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.5}h1,h3{margin:0}h1{font-size:clamp(22px,2.2vw,28px)}h3{font-size:16px;font-weight:600}.subtitle{color:#6b7280;font-size:13px}.page{max-width:1120px;margin:40px auto;padding:0 16px}.page__header{display:grid;grid-template-columns:1fr auto;gap:16px 24px;align-items:start;margin-bottom:20px}.page__header p{color:#6b7280;margin-top:6px}@media (max-width: 720px){.page__header{grid-template-columns:1fr}}.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:flex-end}@media (max-width: 720px){.filters{justify-content:flex-start}}.filter-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid #e5e7eb;padding:10px 12px;border-radius:14px;font-size:14px;color:#0f172a;box-shadow:0 8px 20px #0206170f;cursor:pointer}.filter-btn:hover{border-color:#ced2d9}.filter-btn .icon{font-size:16px;line-height:1}.slots-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px;margin-top:12px}.slot-card{display:grid;grid-template-rows:auto 1fr auto;gap:14px;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px;box-shadow:0 8px 20px #0206170f;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.slot-card:hover{transform:translateY(-2px);border-color:#a7c0f7;box-shadow:0 10px 24px #02061714}.slot-card__header{display:grid;grid-template-columns:48px 1fr;gap:12px;align-items:center}.slot-card__avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid rgb(152.8305439331,182.2217573222,245.6694560669)}.slot-card__title{display:flex;flex-direction:column;gap:2px}.slot-card__meta{list-style:none;margin:0;padding:8px 0 0;display:grid;gap:10px}.slot-card__meta li{display:grid;grid-template-columns:22px 1fr;align-items:start;gap:8px;padding:8px 10px;border:1px dashed #e5e7eb;border-radius:12px;background:#fafafa}.slot-card__meta li .icon{font-size:16px;line-height:1;margin-top:2px}.slot-card__meta li .meta{display:flex;flex-direction:column}.slot-card__meta li .label{font-size:12px;color:#6b7280}.slot-card__meta li .value{font-size:14px;color:#0f172a;font-weight:500}.slot-card__action{margin-top:4px;display:flex;justify-content:center}.btn-primary{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:#2463eb;color:#fff;font-weight:600;font-size:14px;padding:12px 16px;width:100%;border-radius:12px;cursor:pointer;transition:background-color .15s ease,transform .04s ease}.btn-primary:hover{background:#1659ea}.btn-primary:active{transform:translateY(1px);background:#1350d3}.pager{display:flex;align-items:center;gap:12px;justify-content:center;margin:18px 0 32px}.pager__nav{padding:10px 14px;border:1px solid #e5e7eb;background:#fff;border-radius:10px;cursor:pointer;font-weight:600}.pager__nav:disabled{opacity:.5;cursor:not-allowed}.pager__list{display:flex;gap:6px;flex-wrap:wrap}.pager__num{min-width:38px;height:38px;padding:0 10px;border:1px solid #e5e7eb;background:#fff;border-radius:10px;cursor:pointer;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.pager__num.is-active{background:#2463eb;color:#fff;border-color:#2463eb}html,body{margin:0;padding:0;background-color:#fff;height:100%;box-sizing:border-box}.dashboard{display:flex;min-height:100vh;background:linear-gradient(to bottom right,#f5f3ff,#fff,#eef2ff)}.dashboard .dashboard-sidebar{width:250px;height:100vh;background-color:#fff;color:#111827;display:flex;flex-direction:column;padding:1.5rem 1rem;border-right:1px solid #e5e7eb}.dashboard .dashboard-sidebar .sidebar-header{display:flex;align-items:center;gap:.5rem;padding:0 .75rem;margin-bottom:2rem}.dashboard .dashboard-sidebar .sidebar-header .logo-icon{width:32px;height:32px}.dashboard .dashboard-sidebar .sidebar-header .logo-text{font-weight:700;font-size:1.2rem}.dashboard .dashboard-sidebar .sidebar-nav{flex-grow:1}.dashboard .dashboard-sidebar .sidebar-nav ul{list-style:none;padding:0;margin:0}.dashboard .dashboard-sidebar .sidebar-nav ul .logo-icon-home,.dashboard .dashboard-sidebar .sidebar-nav ul .logo-icon-consult{width:20px;height:20px}.dashboard .dashboard-sidebar .sidebar-nav ul .nav-item{display:flex;align-items:center;justify-content:flex-start;padding:.75rem 1rem;margin-bottom:.5rem;border-radius:8px;font-weight:500;cursor:pointer;position:relative;transition:background .3s}.dashboard .dashboard-sidebar .sidebar-nav ul .nav-item:hover{background-color:#e0e7ff}.dashboard .dashboard-sidebar .sidebar-nav ul .nav-item.active{background-color:#3b82f6;color:#fff}.dashboard .dashboard-sidebar .sidebar-nav ul .nav-item.active .badge{background-color:#fff;color:#3b82f6}.dashboard .dashboard-sidebar .sidebar-nav ul .nav-item .icon{margin-right:12px;font-size:1.1rem;color:#111827;display:flex;align-items:center;justify-content:center;width:24px}.dashboard .dashboard-sidebar .sidebar-nav ul .nav-item .label{flex:1;text-align:left}.dashboard .dashboard-sidebar .sidebar-nav ul .nav-item .badge{background-color:#facc15;color:#111827;font-size:.75rem;padding:.2rem .5rem;border-radius:999px;margin-left:auto}.dashboard .dashboard-sidebar .sidebar-nav ul .nav-item .badge.orange{background-color:#f97316;color:#fff}.dashboard .dashboard-sidebar .sidebar-extra{margin-top:auto}.dashboard .dashboard-sidebar .sidebar-extra .contact-btn{width:100%;padding:1rem;background-color:#f3f4f6;border-radius:8px;font-weight:500;margin-bottom:1rem;text-align:left;border:none;display:flex;align-items:center;gap:.5rem}.dashboard .dashboard-sidebar .sidebar-extra .contact-btn .icon{color:#6b7280}.dashboard .dashboard-sidebar .sidebar-extra .gift-card{background:#fff7ed;padding:.75rem;border-radius:10px;display:flex;gap:.75rem;align-items:center;font-size:.875rem;box-shadow:0 0 0 1px #f97316}.dashboard .dashboard-sidebar .sidebar-extra .gift-card p{margin:0;font-weight:700}.dashboard .dashboard-sidebar .sidebar-extra .gift-card small{color:#9ca3af}.dashboard .dashboard-sidebar .sidebar-extra .gift-card .icon{color:#f97316}.dashboard .dashboard-sidebar .sidebar-footer{padding-top:1rem}.dashboard .dashboard-sidebar .sidebar-footer .logout-btn{background:none;border:none;color:#ef4444;font-weight:600;display:flex;align-items:center;gap:.5rem;cursor:pointer}.dashboard .dashboard-sidebar .sidebar-footer .logout-btn:hover{text-decoration:underline}.dashboard .dashboard-sidebar .sidebar-footer .logout-btn .icon{font-size:1.2rem}.dashboard .dashboard-main{flex:1;padding:2rem;padding:0}.dashboard .dashboard-main .dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;margin:0 -2rem 2rem;background-color:#fff;border-bottom:1px solid #e5e7eb;border-radius:0 0 12px 12px;position:sticky;top:0;z-index:5}.dashboard .dashboard-main .dashboard-header h1{font-size:1.6rem;font-weight:600;color:#111827}.dashboard .dashboard-main .dashboard-header .header-actions{display:flex;align-items:center;gap:1rem}.dashboard .dashboard-main .dashboard-header .header-actions .user-btn{background:#fff7ed;border:none;padding:.4rem .8rem;border-radius:10px;font-size:.95rem;color:#333;font-weight:500;box-shadow:0 2px 6px #0000000d;display:flex;align-items:center;gap:.4rem;cursor:pointer}.dashboard .dashboard-main .dashboard-header .header-actions .user-btn .arrow{font-size:.75rem;color:#6b7280}.dashboard .dashboard-main .dashboard-header .header-actions .notification-btn{background:none;border:none;font-size:1.2rem;color:#3b82f6;cursor:pointer;position:relative}.dashboard .dashboard-main .dashboard-header .header-actions .notification-btn .icon{width:20px}.dashboard .dashboard-main .dashboard-header .header-actions .notification-btn:hover{opacity:.8}.dashboard .dashboard-main .dashboard-header .header-actions .profile-avatar{width:30px;border-radius:50%;object-fit:cover;border:2px solid #ddd}.dashboard .dashboard-main .dashboard-content .dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem;margin-left:20px;margin-right:10px}.dashboard .dashboard-main .dashboard-content .dashboard-grid .card-mental{background-color:#f9fafb;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000000d;color:#111827;display:flex;flex-direction:column;gap:1rem;transition:box-shadow .3s ease}.dashboard .dashboard-main .dashboard-content .dashboard-grid .card-mental:hover{box-shadow:0 6px 18px #00000014}.dashboard .dashboard-main .dashboard-content .dashboard-grid .card-mental .card-header{display:flex;align-items:center;justify-content:space-between}.dashboard .dashboard-main .dashboard-content .dashboard-grid .card-mental .card-header .card-icon{background:#eef2ff;color:#4338ca;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1rem}.dashboard .dashboard-main .dashboard-content .dashboard-grid .card-mental .card-header .card-icon img{width:24px;height:24px}.dashboard .dashboard-main .dashboard-content .dashboard-grid .card-mental .card-header .card-title{font-weight:600;margin-left:.5rem;flex-grow:1;color:#1f2937}.dashboard .dashboard-main .dashboard-content .dashboard-grid .card-mental .card-header .card-options{font-size:1.5rem;color:#9ca3af;cursor:pointer}.dashboard .dashboard-main .dashboard-content .dashboard-grid .card-mental .card-body .card-value{font-size:2rem;font-weight:700;margin:0;color:#111827}.dashboard .dashboard-main .dashboard-content .dashboard-grid .card-mental .card-body .card-value .card-change{font-size:1rem;font-weight:500;color:#16a34a;margin-left:.5rem}.dashboard .dashboard-main .dashboard-content .dashboard-grid .card-mental .card-body .card-description{margin-top:.5rem;font-size:.875rem;color:#6b7280}.dashboard .dashboard-main .dashboard-content .resource-container{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-top:2rem;margin-left:20px;margin-right:10px}.dashboard .dashboard-main .dashboard-content .resource-container .card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 12px #0000000d}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 12px #0000000d;display:flex;flex-direction:column;gap:1.25rem}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-header{display:flex;justify-content:space-between;align-items:center}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-header h3{font-size:1.1rem;font-weight:600;margin:0}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-header .view-all{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;font-size:.875rem;font-weight:600;color:#be123c;background-color:transparent;border-radius:9999px;cursor:pointer;transition:all .25s ease;outline:none;border:1px solid #be123c}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-header .view-all:hover{background-color:#be123c;color:#fff;box-shadow:0 4px 8px #be123c33}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-header .view-all:active{transform:scale(.97)}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item{display:flex;justify-content:space-between;align-items:center;border-radius:12px;padding:1rem;background:#f9fafb}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item.active{background:#fdf2f8}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item .appointment-info{display:flex;flex-direction:column;gap:.5rem}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item .appointment-info h4{font-size:1rem;font-weight:600;margin:0}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item .appointment-info .meta{display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:#6b7280}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item .appointment-info .meta .avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item .btn{border:none;padding:.5rem .9rem;font-size:.85rem;border-radius:8px;font-weight:500;cursor:pointer;white-space:nowrap}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item .join{background-color:#be185d;color:#fff}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item .cancel{background:#fff;color:#dc2626;border:1px solid #dc2626;margin-right:.5rem}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item .reschedule{background:#f3f4f6;color:#111827}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item .actions{display:flex}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 4px 12px #0000000d;display:flex;flex-direction:column;gap:1.2rem;max-width:360px}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card .profile-header{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card .profile-header .profile-photo{width:72px;height:72px;border-radius:50%;object-fit:cover}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card .profile-header h3{margin:0;font-size:1.2rem;font-weight:600}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card .profile-header .profile-age{color:#6b7280;font-size:.9rem}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card .profile-header .profile-info{display:flex;justify-content:space-between;gap:1.5rem;margin-top:.5rem}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card .profile-header .profile-info .label{font-size:.75rem;color:#9ca3af;margin:0}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card .profile-header .profile-info .value{font-weight:600;font-size:.95rem;color:#111827;margin:0}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card .card-section{background:#f9fafb;border-radius:12px;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card .card-section .section-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;color:#111827}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card .card-section .section-header span.arrow{font-size:1rem;color:#9ca3af}.dashboard .dashboard-main .dashboard-content .dashboard-row{display:flex;gap:2rem;flex-wrap:wrap}.dashboard .dashboard-main .dashboard-content .dashboard-row .chart-card,.dashboard .dashboard-main .dashboard-content .dashboard-row .tip-card{flex:1;min-width:300px;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000000d}.dashboard .dashboard-main .dashboard-content .dashboard-row .dummy-chart{height:150px;background:#ececf9;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#999}@media (min-width: 1600px){.dashboard .dashboard-sidebar{width:300px;padding:1.75rem 1.25rem}.dashboard .dashboard-main .dashboard-header{padding:1.25rem 2.5rem}.dashboard .dashboard-main .dashboard-content .dashboard-grid{grid-template-columns:repeat(3,minmax(280px,1fr));gap:2rem;margin-left:24px;margin-right:16px}.dashboard .dashboard-main .dashboard-content .resource-container{grid-template-columns:2fr 1fr;gap:2rem;margin-left:24px;margin-right:16px}}@media (min-width: 1280px) and (max-width: 1599px){.dashboard .dashboard-sidebar{width:260px}.dashboard .dashboard-main .dashboard-header{padding:1rem 2rem}.dashboard .dashboard-main .dashboard-content .dashboard-grid{grid-template-columns:repeat(3,minmax(260px,1fr));gap:1.75rem}.dashboard .dashboard-main .dashboard-content .resource-container{grid-template-columns:2fr 1fr;gap:1.5rem}}@media (min-width: 1024px) and (max-width: 1279px){.dashboard .dashboard-sidebar{width:230px}.dashboard .dashboard-main .dashboard-header{padding:.85rem 1.5rem}.dashboard .dashboard-main .dashboard-header h1{font-size:1.45rem}.dashboard .dashboard-main .dashboard-content .dashboard-grid{grid-template-columns:repeat(2,minmax(260px,1fr));gap:1.25rem;margin-left:16px;margin-right:12px}.dashboard .dashboard-main .dashboard-content .resource-container{grid-template-columns:1fr;gap:1.25rem}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card{max-width:100%}}@media (min-width: 768px) and (max-width: 1023px) and (orientation: portrait){.dashboard .dashboard-sidebar{width:220px}.dashboard .dashboard-main .dashboard-header{padding:.75rem 1.25rem}.dashboard .dashboard-main .dashboard-header h1{font-size:1.35rem}.dashboard .dashboard-main .dashboard-content .dashboard-grid{grid-template-columns:repeat(2,minmax(240px,1fr));gap:1.1rem;margin-left:12px;margin-right:10px}.dashboard .dashboard-main .dashboard-content .resource-container{grid-template-columns:1fr;gap:1.1rem}.dashboard .dashboard-main .dashboard-content .resource-container .profile-card{max-width:100%}}@media (max-width: 767px){.dashboard{display:block}.dashboard .dashboard-sidebar{position:fixed;inset:0 auto 0 0;width:min(88vw,320px);height:100dvh;transform:translate(-100%);transition:transform .25s ease;box-shadow:8px 0 24px #00000014;z-index:40}.dashboard .dashboard-sidebar .sidebar-nav{padding-bottom:120px}.dashboard .dashboard-sidebar.is-open{transform:translate(0)}.dashboard .sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:30}.dashboard .sidebar-backdrop.is-open{opacity:1;pointer-events:auto}.dashboard .dashboard-main{padding:0}.dashboard .dashboard-main .dashboard-header{padding:.65rem 1rem;margin:0 0 1rem}.dashboard .dashboard-main .dashboard-header h1{font-size:1.2rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard .dashboard-main .dashboard-content .dashboard-grid,.dashboard .dashboard-main .dashboard-content .resource-container{grid-template-columns:1fr;gap:1rem;margin-left:10px;margin-right:10px}.dashboard .dashboard-main .dashboard-content .resource-container .appointment-card .appointment-item{align-items:flex-start;gap:.75rem;flex-direction:column}}@media (max-width: 414px){.dashboard .dashboard-sidebar{width:86vw}.dashboard .dashboard-main .dashboard-header{padding:.6rem .9rem}}@media (max-width: 375px){.dashboard .dashboard-sidebar{width:88vw}.dashboard .dashboard-main .dashboard-header{padding:.55rem .85rem}.dashboard .dashboard-main .dashboard-header h1{font-size:1.1rem}.dashboard .dashboard-main .dashboard-content .appointment-card .appointment-header h3{font-size:1rem}}@media (max-width: 320px){.dashboard .dashboard-sidebar{width:92vw}.dashboard .dashboard-main .dashboard-header{padding:.5rem .75rem}.dashboard .dashboard-main .dashboard-header h1{font-size:1.05rem}.dashboard .dashboard-main .dashboard-content .dashboard-grid{gap:.85rem}}:root{--primary: #4361ee;--primary-light: #eef2ff;--success: #10b981;--success-light: #d1fae5;--danger: #ef4444;--danger-light: #fee2e2;--warning: #f59e0b;--warning-light: #fef3c7;--info: #3b82f6;--info-light: #dbeafe;--gray-100: #f8f9fa;--gray-200: #e9ecef;--gray-300: #dee2e6;--gray-400: #ced4da;--gray-500: #adb5bd;--gray-600: #6c757d;--gray-700: #495057;--gray-800: #343a40;--gray-900: #212529;--border-radius: 8px;--box-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--transition: all .2s ease-in-out}.feedback-results{padding:1.5rem;max-width:1400px;margin:0 auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--gray-800)}.feedback-results .page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.feedback-results .page-header h1{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin:0 0 .5rem}.feedback-results .page-header p{color:var(--gray-600);margin:0;font-size:.95rem}.feedback-results .card{background:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);overflow:hidden;margin-bottom:2rem}.feedback-results .card .card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.feedback-results .search-box-feedback{display:flex;align-items:center;gap:12px;width:100%;max-width:580px;margin:0}.feedback-results .search-box-feedback>input[type=text]{flex:1 1 auto;height:44px;padding:0 14px;border:1.5px solid #e5e7eb;border-radius:12px;background:#fff;font-size:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.feedback-results .search-box-feedback>input[type=text]::placeholder{color:#9ca3af}.feedback-results .search-box-feedback>input[type=text]:hover{border-color:#cbd5e1}.feedback-results .search-box-feedback>input[type=text]:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.feedback-results .table-feedback{width:100%;overflow-x:auto;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:1rem}.feedback-results .feedback-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.feedback-results .feedback-table .feedback-head-table{background:#f9fafb}.feedback-results .feedback-table .feedback-head-table th{text-align:left;padding:12px 16px;font-weight:600;color:#374151;font-size:13px;border-bottom:1px solid #e5e7eb;border-right:none;border:none}.feedback-results .feedback-table .feedback-head-table th:nth-child(1){padding-left:10px}.feedback-results .feedback-table .feedback-head-table th:nth-child(2){padding-left:28px}.feedback-results .feedback-table .feedback-head-table th:nth-child(3){padding-left:40px}.feedback-results .feedback-table .feedback-head-table th:nth-child(5){padding-left:90px}.feedback-results .feedback-table .data-feedback tr{border-bottom:1px solid #f1f1f1;transition:background .2s}.feedback-results .feedback-table .data-feedback tr:hover{background:#f9f9fb}.feedback-results .feedback-table .data-feedback tr td{padding:12px 16px;vertical-align:middle;color:#374151;border:none}.feedback-results .feedback-table .data-feedback tr td .user-cell{display:flex;align-items:center;gap:10px}.feedback-results .feedback-table .data-feedback tr td .user-cell img{width:34px;height:34px;border-radius:50%;object-fit:cover}.feedback-results .feedback-table .data-feedback tr td .user-cell .user-name{font-weight:500;color:#111827}.feedback-results .feedback-table .data-feedback tr td .role-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:4px 10px;border-radius:20px}.feedback-results .feedback-table .data-feedback tr td .role-badge.role-1{background:#dbeafe;color:#1d4ed8}.feedback-results .feedback-table .data-feedback tr td .role-badge.role-2{background:#46c04c;color:#f1f1f1}.feedback-results .feedback-table .data-feedback tr td .role-badge.role-3{background:#508acc;color:#edf0ee}.feedback-results .feedback-table .data-feedback tr td .role-badge.role-4{background:#fd902a;color:#fff}.feedback-results .feedback-table .data-feedback tr td .role-badge.role-5{background:#f0f0f0;color:#000}.feedback-results .feedback-table .data-feedback tr td .action-buttons{display:flex;align-items:center;gap:8px}.feedback-results .feedback-table .data-feedback tr td .action-buttons .btn-action{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;border:none;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s ease}.feedback-results .feedback-table .data-feedback tr td .action-buttons .btn-action svg{font-size:14px}.feedback-results .feedback-table .data-feedback tr td .action-buttons .btn-action.btn-edit{background:#e0f2fe;color:#0369a1}.feedback-results .feedback-table .data-feedback tr td .action-buttons .btn-action.btn-edit:hover{background:#bae6fd}.feedback-results .feedback-table .data-feedback tr td .action-buttons .btn-action.btn-delete{background:#fee2e2;color:#b91c1c}.feedback-results .feedback-table .data-feedback tr td .action-buttons .btn-action.btn-delete:hover{background:#fecaca}.feedback-results .feedback-table .data-feedback tr td .action-buttons .btn-action.btn-warning{background:#fef9c3;color:#92400e}.feedback-results .feedback-table .data-feedback tr td .action-buttons .btn-action.btn-warning:hover{background:#fde68a}.feedback-results .feedback-table .data-feedback tr td:nth-child(2){padding-left:28px}.feedback-results .feedback-table .data-feedback tr .no-results{text-align:center;padding:40px;color:#6b7280}.feedback-results .feedback-table .data-feedback tr .no-results h3{margin-top:8px;font-size:15px}.feedback-results .star-rating{display:flex;align-items:center;gap:.25rem}.feedback-results .star-rating .star{color:#e2e8f0;font-size:1.1rem;line-height:1}.feedback-results .star-rating .star.filled{color:#f59e0b}.feedback-results .star-rating .rating-text{margin-left:.5rem;font-size:.9rem;color:var(--gray-600);font-weight:500}.pagination-role{display:flex;justify-content:center;align-items:center;gap:8px;padding:6px;background:#f1f3f5;border-radius:12px;width:fit-content;margin:1rem auto 0}.pagination-role .page-btn{width:36px;height:36px;border:0;outline:0;border-radius:10px;background:#fff;color:#6b7280;font-weight:700;font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #1018280f;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,color .12s ease}.pagination-role .page-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1018281a}.pagination-role .page-btn:focus-visible{box-shadow:0 0 0 3px #2563eb40}.pagination-role .page-btn.is-active{background:#1f2a44;color:#fff}.pagination-role .page-btn.nav-btn{width:36px;min-width:36px}.pagination-role .page-btn.nav-btn svg{display:block}.pagination-role .page-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:0 2px 6px #1018280a}@media (max-width: 420px){.pagination-role{gap:6px}.pagination-role .page-btn{width:32px;height:32px;border-radius:8px;font-size:13px}}.detail-konsultasi-admin{padding:2rem}.detail-konsultasi-admin .section{margin-bottom:2rem}.detail-konsultasi-admin .section .section-title{font-size:22px;font-weight:700;color:#111518;margin-bottom:1rem}.detail-konsultasi-admin .section .grid-two{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.detail-konsultasi-admin .section .field{border-top:1px solid #dbe1e6;padding-top:1rem}.detail-konsultasi-admin .section .field .label{color:#617989;font-size:.875rem}.detail-konsultasi-admin .section .field .value{color:#111518;font-size:.875rem}.detail-konsultasi-admin .section .history-grid{display:grid;grid-template-columns:20% 1fr;column-gap:1.5rem}.detail-konsultasi-admin .section .history-grid .history-item{grid-column:span 2;border-top:1px solid #dbe1e6;padding-top:1.25rem}.detail-konsultasi-admin .section .history-grid .history-item .label{color:#617989;font-size:.875rem}.detail-konsultasi-admin .section .history-grid .history-item .value{color:#111518;font-size:.875rem}.detail-konsultasi-admin .section .notes{padding:1rem 0;color:#111518;font-size:1rem}.back-button-container{padding:2rem 0;display:flex;justify-content:flex-start}.btn-back{background-color:#2563eb;color:#fff;border:none;border-radius:8px;padding:.5rem 1.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .3s ease,transform .2s ease}.btn-back:hover{background-color:#1d4ed8;transform:translateY(-1px)}.btn-back:active{background-color:#1e40af;transform:translateY(0)}.btn-back:focus{outline:2px solid #3b82f6;outline-offset:2px}:root{--modal-bg: #ffffff;--modal-border: rgba(20, 31, 46, .08);--modal-shadow: 0 24px 80px rgba(0, 0, 0, .22);--primary: #151E2D;--text: #182230;--muted: #6b7280;--ring: rgba(21, 30, 45, .3);--radius: 16px;--gap: 14px}.modal-backdrop.modern{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0e136b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;padding:24px;z-index:1000;animation:fadeIn .15s ease-out}.modal-card.modern{width:100%;max-width:860px;background:var(--modal-bg);border:1px solid var(--modal-border);border-radius:var(--radius);box-shadow:var(--modal-shadow);overflow:hidden;transform:translateY(8px) scale(.98);animation:popIn .18s ease-out forwards}.modal-header.modern{position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:radial-gradient(80% 100% at 0% 0%,rgba(21,30,45,.06),transparent 60%),#fff;border-bottom:1px solid var(--modal-border)}.modal-title{margin:0;font-size:1.1rem;font-weight:700;color:var(--text)}.icon-btn.close{background:transparent;border:none;font-size:24px;line-height:1;cursor:pointer;color:var(--muted);padding:6px 8px;border-radius:10px;transition:background .15s ease,color .15s ease,transform .05s ease}.icon-btn.close:hover{background:#0000000f;color:var(--text)}.icon-btn.close:active{transform:scale(.98)}.modal-body.modern{padding:18px;max-height:min(78vh,860px);overflow:auto}.form-grid.modern{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--gap)}.form-grid.modern .col-span-2{grid-column:span 2}.form-grid.modern .row{display:flex;align-items:center;gap:10px}label>span{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}.input,.select,.textarea{width:100%;padding:10px 12px;border:1px solid #e6eaf2;border-radius:10px;background:#fff;color:var(--text);transition:border-color .12s ease,box-shadow .12s ease}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 3px #151e2d1a}.checkbox{display:inline-flex;align-items:center;gap:10px;font-size:14px;color:var(--text)}.checkbox input{width:18px;height:18px;accent-color:var(--primary)}.modal-actions.modern{position:sticky;bottom:0;z-index:1;display:flex;justify-content:flex-end;gap:10px;padding:14px 18px;background:linear-gradient(to top,#fffffff2,#ffffffeb),#fff;border-top:1px solid var(--modal-border)}.btn{padding:10px 16px;border-radius:12px;border:1px solid transparent;cursor:pointer;font-weight:600;transition:transform .05s ease,filter .12s ease,background .15s ease,color .15s ease}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--primary);color:#fff}.btn.primary:hover{filter:brightness(.95)}.btn.ghost{background:#fff;border-color:#e6eaf2;color:var(--text)}.btn.ghost:hover{background:#f7f8fa}@media (max-width: 680px){.modal-card.modern{max-width:100%}.form-grid.modern{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{to{transform:translateY(0) scale(1)}}
