:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: #e74c3c;--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-toast-width: 320px;--toastify-toast-background: #fff;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient( to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55 );--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error)}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;padding:4px;width:var(--toastify-toast-width);box-sizing:border-box;color:#fff}.Toastify__toast-container--top-left{top:1em;left:1em}.Toastify__toast-container--top-center{top:1em;left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:1em;right:1em}.Toastify__toast-container--bottom-left{bottom:1em;left:1em}.Toastify__toast-container--bottom-center{bottom:1em;left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:1em;right:1em}@media only screen and (max-width : 480px){.Toastify__toast-container{width:100vw;padding:0;left:0;margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:0;transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:0;transform:translate(0)}.Toastify__toast-container--rtl{right:0;left:initial}}.Toastify__toast{position:relative;min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:8px;border-radius:4px;box-shadow:0 1px 10px #0000001a,0 2px 15px #0000000d;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;max-height:var(--toastify-toast-max-height);overflow:hidden;font-family:var(--toastify-font-family);cursor:default;direction:ltr;z-index:0}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{margin:auto 0;-ms-flex:1 1 auto;flex:1 1 auto;padding:6px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.Toastify__toast-body>div:last-child{word-break:break-word;-ms-flex:1;flex:1}.Toastify__toast-icon{-webkit-margin-end:10px;margin-inline-end:10px;width:20px;-ms-flex-negative:0;flex-shrink:0;display:-ms-flexbox;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.7s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}@media only screen and (max-width : 480px){.Toastify__toast{margin-bottom:0;border-radius:0}}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;-ms-flex-item-align:start;align-self:flex-start}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:5px;z-index:var(--toastify-z-index);opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,0,0)}to{opacity:0;transform:translate3d(2000px,0,0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,0,0)}to{opacity:0;transform:translate3d(-2000px,0,0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,-10px,0)}40%,45%{opacity:1;transform:translate3d(0,20px,0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,10px,0)}40%,45%{opacity:1;transform:translate3d(0,-20px,0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:perspective(400px)}30%{transform:perspective(400px) rotateX(-20deg);opacity:1}to{transform:perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideOutRight{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(110%,0,0)}}@keyframes Toastify__slideOutLeft{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(-110%,0,0)}}@keyframes Toastify__slideOutDown{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-page{min-height:100vh;display:flex;background:#d4f5d4;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;left:-10%;width:70%;height:200%;background:#c8f5c8;border-radius:50%;z-index:0}.login-left{flex:1;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;padding:40px}.login-illustration{max-width:600px;width:100%}.login-illustration svg{width:100%;height:auto}.login-right{flex:0 0 500px;display:flex;align-items:center;justify-content:center;padding:40px;position:relative;z-index:1}.login-card{background:#fff;border:2.5px solid #8bc34a;border-radius:18px;padding:35px 32px;width:100%;max-width:380px;box-shadow:0 10px 30px #0000001a}.login-logo{text-align:left;margin-bottom:25px}.login-logo img{width:140px;height:auto;display:block}.login-title{font-size:1.25rem;color:#2d3436;font-weight:600;margin-bottom:25px;text-align:left}.login-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:7px}.form-group label{font-weight:500;color:#2d3436;font-size:.9rem}.form-group input{padding:11px 14px;border:1px solid #dfe6e9;border-radius:6px;font-size:.9rem;transition:all .3s ease;background:#fff}.form-group input:focus{border-color:#8bc34a;outline:none;box-shadow:0 0 0 3px #8bc34a1a}.form-group input::placeholder{color:#b2bec3}.password-input{position:relative;display:flex;align-items:center}.password-input input{width:100%;padding-right:45px}.toggle-password{position:absolute;right:12px;background:none;border:none;color:#636e72;font-size:1.1rem;cursor:pointer;padding:8px;display:flex;align-items:center;transition:color .3s ease}.toggle-password:hover{color:#8bc34a}.forgot-password{text-align:right;margin-top:-6px;margin-bottom:3px}.forgot-password a{color:#636e72;font-size:.85rem;text-decoration:none;transition:color .3s ease}.forgot-password a:hover{color:#8bc34a}.btn-login{padding:13px;background:#8bc34a;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:8px;letter-spacing:.2px}.btn-login:hover:not(:disabled){background:#7cb342;transform:translateY(-2px);box-shadow:0 5px 15px #8bc34a4d}.btn-login:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 1024px){.login-left{display:none}.login-right{flex:1}}@media (max-width: 768px){.login-page:before{width:100%;left:0}.login-right{padding:20px}.login-card{padding:30px 25px}.login-logo h1{font-size:1.3rem}.login-title{font-size:1.1rem}}.sidebar{width:var(--sidebar-width);height:100vh;background:#fff;border-right:1px solid #e9ecef;display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:1000;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar-logo{padding:20px;height:var(--header-height);display:flex;align-items:center;border-bottom:1px solid #e9ecef}.sidebar-logo img{max-width:100%;height:35px;object-fit:contain}.sidebar-user{padding:20px;display:flex;align-items:center;gap:12px;background:#fcfcfc;border-bottom:1px solid #e9ecef}.user-avatar{min-width:40px;height:40px;border-radius:10px;background:#e8f5e9;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:#8bc34a}.user-info{flex:1;min-width:0}.user-name{font-weight:600;font-size:.9rem;color:#2d3436;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:#636e72}.sidebar-nav{flex:1;padding:15px 10px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 15px;color:#636e72;text-decoration:none;transition:all .2s ease;font-size:.95rem;border-radius:10px;margin-bottom:4px}.nav-item:hover{background:#f8f9fa;color:#8bc34a}.nav-item.active{background:#e8f5e9;color:#8bc34a;font-weight:600}.nav-icon{font-size:1.2rem}.sidebar-logout{padding:15px 20px;background:none;border:none;color:#e74c3c;font-size:.95rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:12px;border-top:1px solid #e9ecef;transition:background .2s ease}.sidebar-logout:hover{background:#fff5f5}.sidebar-toggle{display:none;position:fixed;top:15px;left:15px;z-index:1001;background:#fff;color:#2d3436;border:1px solid #e9ecef;width:40px;height:40px;border-radius:10px;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0000000d}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999;opacity:0;transition:opacity .3s ease}@media (max-width: 1024px){.sidebar{width:var(--sidebar-collapsed-width)}.sidebar-logo{justify-content:center;padding:10px}.sidebar-logo img{height:30px}.sidebar-user{justify-content:center;padding:15px 0}.user-info,.user-role{display:none}.nav-item{justify-content:center;padding:12px}.nav-item span{display:none}.sidebar-logout{justify-content:center}.sidebar-logout span{display:none}}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:280px!important}.sidebar.open{transform:translate(0)}.sidebar-toggle{display:flex}.sidebar-overlay.show{display:block;opacity:1}.user-info{display:block!important}.nav-item{justify-content:flex-start!important}.nav-item span,.sidebar-logout span{display:inline!important}}.dashboard-header{height:var(--header-height);background:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 30px;position:sticky;top:0;z-index:100;border-bottom:1px solid #e9ecef}.header-search{position:relative;flex:0 1 400px}.header-search input{width:100%;padding:10px 15px 10px 45px;border:1px solid #dfe6e9;border-radius:10px;font-size:.9rem;background:#f8f9fa;transition:all .2s ease}.header-search input:focus{background:#fff;border-color:#8bc34a;box-shadow:0 0 0 3px #8bc34a1a}.search-icon{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:#636e72;font-size:1.1rem}.header-right{display:flex;align-items:center;gap:15px}.header-date{color:#636e72;font-size:.85rem;font-weight:500;background:#f8f9fa;padding:8px 15px;border-radius:8px}.user-avatar-small{width:40px;height:40px;border-radius:10px;background:#8bc34a;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}@media (max-width: 1024px){.dashboard-header{padding:0 20px}}@media (max-width: 768px){.dashboard-header{padding:0 15px 0 70px}.header-search,.header-date{display:none}}@media (max-width: 480px){.dashboard-header{padding:0 10px 0 60px}}.dashboard-layout{display:flex;min-height:100vh;background:#f8f9fa}.dashboard-main{flex:1;margin-left:var(--sidebar-width);transition:margin .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;min-width:0}@media (max-width: 1024px){.dashboard-main{margin-left:var(--sidebar-collapsed-width)}}@media (max-width: 768px){.dashboard-main{margin-left:0}}.welcome-section{margin-bottom:30px}.welcome-section h1{font-size:1.8rem;color:#2d3436;margin-bottom:5px}.welcome-section p{color:#636e72;font-size:.95rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;padding:20px;border-radius:15px;border:1px solid #e9ecef;display:flex;align-items:center;gap:15px;box-shadow:0 2px 5px #00000005;transition:transform .2s ease}.stat-card:hover{transform:translateY(-3px);box-shadow:0 5px 15px #0000000d}.stat-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem}.stat-info h3{font-size:1.5rem;color:#2d3436;font-weight:700;margin-bottom:2px}.stat-info p{color:#636e72;font-size:.85rem;font-weight:500}.stat-trend{display:flex;align-items:center;gap:4px;font-size:.75rem;margin-top:5px}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:25px}@media (max-width: 1200px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-card{background:#fff;border-radius:15px;padding:25px;border:1px solid #e9ecef}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-header h2{font-size:1.1rem;font-weight:600;color:#2d3436}.btn-view-all{padding:8px 12px;border-radius:8px;background:#f8f9fa;color:#8bc34a;font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:5px;transition:all .2s ease}.btn-view-all:hover{background:#e8f5e9}.appointments-list{display:flex;flex-direction:column;gap:12px}.appointment-item{display:flex;align-items:center;gap:15px;padding:12px;border-radius:12px;background:#fcfcfc;border:1px solid #f1f3f5;transition:background .2s ease}.appointment-item:hover{background:#f8f9fa}@media (max-width: 480px){.appointment-item{flex-wrap:wrap;gap:10px}.status-badge-small{margin-left:auto}}.appointment-avatar{width:40px;height:40px;border-radius:10px;background:#e9ecef;color:#495057;display:flex;align-items:center;justify-content:center}.appointment-details{flex:1}.appointment-details h4{font-size:.9rem;margin-bottom:2px}.appointment-details p{font-size:.8rem;color:#636e72}.quick-actions-list{display:flex;flex-direction:column;gap:12px}.action-item{display:flex;align-items:center;gap:15px;padding:15px;border-radius:12px;background:#f8f9fa;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.action-item:hover{background:#fff;border-color:#8bc34a;transform:translate(5px)}.action-icon-small{width:40px;height:40px;border-radius:10px;background:#fff;color:#8bc34a;display:flex;align-items:center;justify-content:center;font-size:1.2rem;box-shadow:0 2px 5px #0000000d}.action-text h4{font-size:.9rem;margin-bottom:2px}.action-text p{font-size:.75rem;color:#636e72}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;gap:20px;flex-wrap:wrap}.btn-add{padding:12px 20px;background:#8bc34a;color:#fff;border-radius:10px;font-weight:600;display:flex;align-items:center;gap:8px;box-shadow:0 4px 10px #8bc34a33}@media (max-width: 480px){.page-header{flex-direction:column;align-items:flex-start}.btn-add{width:100%;justify-content:center}}.filters-bar{display:flex;gap:10px;margin-bottom:25px;overflow-x:auto;padding-bottom:5px;-webkit-overflow-scrolling:touch}.filters-bar button{white-space:nowrap;padding:10px 18px;background:#fff;border:1px solid #dfe6e9;border-radius:10px;font-size:.9rem;font-weight:500;transition:all .2s ease}.filters-bar button.active{background:#8bc34a;color:#fff;border-color:#8bc34a}.appointments-table{background:#fff;border-radius:15px;overflow:hidden;border:1px solid #e9ecef}.appointments-table table{width:100%;border-collapse:collapse}.appointments-table th{padding:15px 20px;background:#f8f9fa;text-align:left;font-size:.85rem;font-weight:600;color:#636e72;border-bottom:1px solid #e9ecef}.appointments-table td{padding:15px 20px;border-bottom:1px solid #f1f3f5;font-size:.9rem}@media (max-width: 992px){.appointments-table{background:transparent;border:none;overflow:visible}.appointments-table thead{display:none}.appointments-table table,.appointments-table tbody,.appointments-table tr,.appointments-table td{display:block;width:100%}.appointments-table tr{margin-bottom:20px;border:1px solid #e9ecef;border-radius:15px;padding:15px;background:#fff;box-shadow:0 2px 5px #00000005}.appointments-table td{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f1f3f5;text-align:right}.appointments-table td:last-child{border-bottom:none;margin-top:10px;justify-content:center}.appointments-table td:before{content:attr(data-label);font-weight:600;text-align:left;color:#636e72;font-size:.8rem;margin-right:15px}}.patient-cell{display:flex;align-items:center;gap:10px}.status-badge{padding:5px 12px;border-radius:20px;font-size:.75rem;font-weight:600}.status-badge.pending{background:#fff3cd;color:#856404}.status-badge.confirmed{background:#d4edda;color:#155724}.action-buttons{display:flex;gap:8px}.btn-icon{width:35px;height:35px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;color:#636e72}.btn-icon:hover{background:#e8f5e9;color:#8bc34a}.pagination{display:flex;justify-content:center;gap:10px;margin-top:30px}.pagination button{padding:8px 15px;border-radius:8px;background:#fff;border:1px solid #dfe6e9;font-size:.85rem;transition:all .2s ease}.pagination button:hover:not(:disabled){border-color:#8bc34a;color:#8bc34a}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination button{padding:8px 15px;border-radius:8px;background:#fff;border:1px solid #dfe6e9;font-size:.85rem}.pagination button.active{background:#8bc34a;color:#fff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#2d3436b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.modal-content{background:#fff;width:100%;max-width:650px;border-radius:24px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040;position:relative;animation:modal-slide-up .3s cubic-bezier(.16,1,.3,1)}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:24px 30px;border-bottom:1px solid #f1f3f5;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff;z-index:10}.modal-header h2{font-size:1.4rem;font-weight:700;color:#2d3436;margin:0}.btn-close{background:#f8f9fa;border:none;width:36px;height:36px;border-radius:50%;font-size:1.5rem;display:flex;align-items:center;justify-content:center;color:#636e72;transition:all .2s ease}.btn-close:hover{background:#ffecec;color:#ff7675;transform:rotate(90deg)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:30px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;font-size:.85rem;color:#636e72;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select,.form-group textarea{padding:14px;border:1.5px solid #edf2f7;border-radius:12px;background:#f8fafc;font-size:1rem;color:#2d3436;transition:all .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#8bc34a;background:#fff;box-shadow:0 0 0 4px #8bc34a1a}.full-width{grid-column:span 2}.details-content,.confirmation-content{padding:30px}.detail-section,.message-section,.channels-section{background:#f8fafc;border-radius:16px;padding:24px;margin-bottom:24px;border:1px solid #edf2f7}.detail-section h3,.message-section h3,.channels-section h3{font-size:.9rem;color:#8bc34a;margin-bottom:20px;text-transform:uppercase;letter-spacing:1px;font-weight:700;border-bottom:2px solid #e8f5e9;padding-bottom:8px;display:inline-block}.section-hint{font-size:.85rem;color:#b2bec3;margin-bottom:15px;margin-top:-15px}.detail-row{display:flex;justify-content:space-between;margin-bottom:15px;font-size:1rem}.detail-label{color:#636e72;font-weight:500}.detail-value{color:#2d3436;font-weight:600}.message-box{background:#fff;padding:20px;border-radius:12px;border:1.5px dashed #edf2f7;color:#636e72;font-style:italic;line-height:1.6}.message-textarea{width:100%;min-height:150px;padding:15px;border:1.5px solid #edf2f7;border-radius:12px;font-family:inherit;font-size:.95rem;line-height:1.5;resize:vertical}.patient-summary{display:flex;align-items:center;gap:20px;margin-bottom:30px;padding:20px;background:linear-gradient(135deg,#f8fafc,#edf2f7);border-radius:16px}.summary-icon{width:60px;height:60px;background:#8bc34a;color:#fff;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;box-shadow:0 8px 16px #8bc34a33}.summary-info h3{margin:0;font-size:1.2rem;color:#2d3436}.summary-info p{margin:5px 0 0;color:#636e72;font-weight:500}.channels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;margin-top:15px}.channel-option{position:relative;display:flex;align-items:center;gap:12px;padding:15px;background:#fff;border:1.5px solid #edf2f7;border-radius:12px;cursor:pointer;transition:all .2s ease}.channel-option input[type=checkbox]{position:absolute;opacity:0}.channel-option:hover{border-color:#8bc34a;background:#fcfdfa}.channel-option.active{border-color:#8bc34a;background:#f1f8e9;box-shadow:0 4px 12px #8bc34a1a}.channel-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.channel-icon.whatsapp{background:#e8f5e9;color:#25d366}.channel-icon.sms{background:#e3f2fd;color:#1976d2}.channel-icon.email{background:#fff3e0;color:#f57c00}.channel-info h4{margin:0;font-size:.9rem;color:#2d3436}.channel-info p{margin:2px 0 0;font-size:.75rem;color:#b2bec3}.modal-actions,.confirmation-actions,.detail-actions{padding:24px 30px;background:#f8fafc;border-top:1px solid #f1f3f5;display:flex;justify-content:flex-end;gap:15px}.btn-cancel,.btn-cancel-confirm{padding:12px 24px;background:#fff;border:1.5px solid #edf2f7;border-radius:12px;font-weight:600;color:#636e72;transition:all .2s ease}.btn-cancel:hover,.btn-cancel-confirm:hover{background:#f1f3f5;color:#2d3436}.btn-submit,.btn-send-confirm,.btn-confirm-large{padding:12px 28px;background:#8bc34a;color:#fff;border:none;border-radius:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 8px 20px #8bc34a4d;transition:all .2s ease}.btn-submit:hover,.btn-send-confirm:hover,.btn-confirm-large:hover{background:#7cb342;transform:translateY(-2px);box-shadow:0 12px 24px #8bc34a66}.btn-reject-large{padding:12px 28px;background:#ff7675;color:#fff;border:none;border-radius:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 8px 20px #ff76754d;transition:all .2s ease}.btn-reject-large:hover{background:#ff5252;transform:translateY(-2px);box-shadow:0 12px 24px #ff767566}.modal-confirmation,.modal-details{max-width:750px}@media (max-width: 768px){.modal-content{max-width:95%}.channels-grid{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.modal-overlay{padding:0}.modal-content{max-height:100vh;border-radius:0;height:100%}.form-grid,.details-content,.confirmation-content{padding:20px}.form-grid{grid-template-columns:1fr;gap:16px}.full-width{grid-column:span 1}.modal-actions,.confirmation-actions,.detail-actions{flex-direction:column-reverse;padding:20px;gap:10px}.modal-actions button,.confirmation-actions button,.detail-actions button{width:100%;padding:16px}.patient-summary{flex-direction:column;text-align:center;padding:25px}.channels-grid{grid-template-columns:1fr}}.page-header{margin-bottom:25px}.search-bar{position:relative;margin-bottom:30px}.search-bar svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:#636e72}.search-bar input{width:100%;padding:12px 15px 12px 45px;border:1px solid #dfe6e9;border-radius:12px;background:#fff;font-size:.95rem;transition:all .2s ease}.search-bar input:focus{border-color:#8bc34a;box-shadow:0 0 0 3px #8bc34a1a}.patients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.patient-card{background:#fff;border-radius:15px;padding:20px;border:1px solid #e9ecef;display:flex;flex-direction:column;gap:15px;transition:all .2s ease}.patient-card:hover{transform:translateY(-3px);box-shadow:0 5px 15px #0000000d}.patient-avatar-large{width:60px;height:60px;border-radius:12px;background:#e8f5e9;color:#8bc34a;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.patient-info h3{font-size:1.1rem;margin-bottom:8px;color:#2d3436}.patient-contact{display:flex;flex-direction:column;gap:5px;margin-bottom:15px}.patient-contact span{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#636e72}.patient-stats{border-top:1px solid #f1f3f5;padding-top:15px}.stat-item{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#8bc34a;font-weight:600}.btn-view-patient{width:100%;padding:10px;border-radius:10px;background:#f8f9fa;color:#2d3436;font-weight:600;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:8px}.btn-view-patient:hover{background:#e8f5e9;color:#8bc34a}.patient-header-section{display:flex;align-items:center;gap:20px;margin-bottom:25px}.patient-avatar-xl{width:80px;height:80px;border-radius:15px;background:#8bc34a;color:#fff;font-size:2.5rem}.modal-patient{max-width:800px}.patient-details-content{padding:20px}.contact-info{display:flex;gap:20px;margin-top:5px}.contact-info span{display:flex;align-items:center;gap:8px;color:#636e72;font-size:.9rem}@media (max-width: 600px){.contact-info{flex-direction:column;gap:8px}}@media (max-width: 480px){.patient-header-section{flex-direction:column;text-align:center}}.history-item{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f8f9fa;border-radius:12px;margin-bottom:10px}@media (max-width: 576px){.history-item{flex-direction:column;align-items:flex-start;gap:10px}}.page-header-refined{margin-bottom:40px}.page-header-refined h1{font-size:2.2rem;color:var(--text-dark);margin-bottom:8px;font-weight:800;letter-spacing:-.5px}.page-header-refined p{color:var(--text-gray);font-size:1.1rem}.messages-toolbar{margin-bottom:35px}.messages-filters-refined{display:flex;gap:12px;background:#f8f9fa;padding:6px;border-radius:14px;width:fit-content}.filter-tab{padding:10px 24px;border-radius:10px;border:none;background:transparent;color:var(--text-gray);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.filter-tab:hover{color:var(--primary-green)}.filter-tab.active{background:var(--white);color:var(--primary-green);box-shadow:0 4px 12px #0000000d}.messages-grid-refined{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:30px}@media (max-width: 768px){.messages-grid-refined{grid-template-columns:1fr;gap:20px}}.message-card-premium{background:var(--white);border-radius:24px;padding:28px;border:1px solid rgba(0,0,0,.04);box-shadow:0 10px 30px #00000005;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;cursor:pointer;position:relative;overflow:hidden}.message-card-premium:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0000000f;border-color:#8bc34a33}.message-card-premium.unread{background:linear-gradient(135deg,#fff,#f9fdf5);border-left:6px solid var(--primary-green)}.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.source-tag{padding:6px 14px;border-radius:8px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.source-tag.accueil{background:#e3f2fd;color:#1565c0}.source-tag.page-contact{background:#f3e5f5;color:#7b1fa2}.card-date{font-size:.85rem;color:var(--text-gray);font-weight:500}.card-author{display:flex;align-items:center;gap:16px;margin-bottom:20px}.author-avatar{width:48px;height:48px;background:#f1f8e9;color:var(--primary-green);border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem}.author-details h3{font-size:1.15rem;color:var(--text-dark);margin-bottom:2px;font-weight:700}.author-details p{font-size:.9rem;color:var(--text-gray)}.card-preview{margin-bottom:24px;flex:1}.card-preview p{color:#555;line-height:1.6;font-size:.98rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card-footer-premium{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid #f8f9fa}.msg-status{font-size:.85rem;font-weight:700;display:flex;align-items:center;gap:8px;color:var(--text-gray)}.unread-dot{width:8px;height:8px;background:var(--primary-green);border-radius:50%;box-shadow:0 0 10px #8bc34a80}.btn-trash{width:36px;height:36px;border-radius:10px;border:none;background:#fff5f5;color:#e53935;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:1rem}.btn-trash:hover{background:#e53935;color:var(--white)}.message-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .3s ease}.message-modal-content{background:var(--white);width:100%;max-width:700px;border-radius:32px;position:relative;overflow:hidden;box-shadow:0 25px 50px -12px #00000040;animation:modalSlideUp .4s cubic-bezier(.16,1,.3,1)}.modal-close-btn{position:absolute;top:24px;right:24px;width:44px;height:44px;border-radius:50%;border:none;background:#f8f9fa;color:var(--text-dark);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;z-index:10;transition:all .2s}.modal-close-btn:hover{background:#e9ecef;transform:rotate(90deg)}.modal-header-premium{padding:40px 40px 30px;background:linear-gradient(to bottom,#f9fdf5,#fff);border-bottom:1px solid #f1f3f5}.modal-source-info{display:flex;justify-content:space-between;margin-bottom:24px}.modal-sender-profile{display:flex;align-items:center;gap:24px}.profile-avatar{width:64px;height:64px;background:var(--primary-green);color:var(--white);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;box-shadow:0 8px 20px #8bc34a4d}.profile-info h2{font-size:1.8rem;color:var(--text-dark);margin-bottom:6px;font-weight:800}.profile-contacts{display:flex;flex-wrap:wrap;gap:16px}.profile-contacts span{display:flex;align-items:center;gap:8px;color:var(--text-gray);font-size:.95rem;font-weight:500}.profile-contacts svg{color:var(--primary-green)}.modal-body-premium{padding:40px}.modal-body-premium h3{font-size:.85rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-gray);margin-bottom:16px;font-weight:800}.message-text-full{font-size:1.1rem;line-height:1.8;color:#374151;white-space:pre-wrap;background:#f9fafb;padding:30px;border-radius:20px;border:1px solid #f1f3f5}.modal-footer-premium{padding:30px 40px;display:flex;justify-content:space-between;align-items:center;background:#fcfcfc;border-top:1px solid #f1f3f5}.btn-modal-delete{padding:12px 20px;border-radius:12px;border:none;background:#fff5f5;color:#e53935;font-weight:700;display:flex;align-items:center;gap:10px;cursor:pointer;transition:all .2s}.btn-modal-delete:hover{background:#e53935;color:var(--white)}.btn-modal-close{padding:12px 30px;border-radius:12px;border:1px solid var(--border-color);background:var(--white);color:var(--text-dark);font-weight:700;cursor:pointer;transition:all .2s}.btn-modal-close:hover{background:#f8f9fa;border-color:#dee2e6}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 0;color:var(--text-gray)}.spinner{width:50px;height:50px;border:4px solid rgba(139,195,74,.1);border-left-color:var(--primary-green);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.empty-state-refined{text-align:center;padding:80px 0;max-width:400px;margin:0 auto}.empty-icon{width:100px;height:100px;background:#f8f9fa;border-radius:40px;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:3rem;color:#dee2e6}.empty-state-refined h3{font-size:1.5rem;color:var(--text-dark);margin-bottom:12px}.empty-state-refined p{color:var(--text-gray)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}.app{min-height:100vh;display:flex;width:100%;overflow-x:hidden;position:relative}.main-content{flex:1;margin-left:250px;min-height:100vh;background:#f8f9fa;transition:margin-left .3s ease;width:calc(100% - 250px);overflow-x:hidden}@media (max-width: 1024px){.main-content{margin-left:70px;width:calc(100% - 70px)}}@media (max-width: 768px){.main-content{margin-left:0;width:100%;padding-top:0}.dashboard-container,.appointments-container,.patients-container,.settings-container{padding-top:80px!important}}@media (max-width: 480px){.main-content{padding-top:0}.dashboard-container,.appointments-container,.patients-container,.settings-container,.dashboard-content{padding-top:75px!important}}.dashboard-content{padding:40px 30px;width:100%;max-width:1600px;margin:0 auto}@media (max-width: 768px){.dashboard-content{padding:25px 20px}}@media (max-width: 480px){.dashboard-content{padding:20px 15px}}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--primary-green: #00b894;--primary-green-dark: #00a383;--primary-green-light: #55efc4;--dark-bg: #2d3436;--light-bg: #f8f9fa;--white: #ffffff;--text-dark: #2d3436;--text-light: #636e72;--border-color: #dfe6e9;--danger: #d63031;--warning: #fdcb6e;--success: #00b894;--info: #0984e3;--sidebar-width: 250px;--sidebar-collapsed-width: 70px;--header-height: 70px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:var(--light-bg);color:var(--text-dark);line-height:1.6;overflow-x:hidden;width:100%}#root{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1400px;margin:0 auto;padding:0 15px}button{cursor:pointer;border:none;outline:none;font-family:inherit;transition:all .2s ease}input,textarea,select{font-family:inherit;outline:none}a{text-decoration:none;color:inherit}.mobile-only{display:none}@media (max-width: 768px){.mobile-only{display:block}.desktop-only{display:none}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#dfe6e9;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#b2bec3}@media (max-width: 768px){html{font-size:15px}}@media (max-width: 480px){html{font-size:14px}}.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:1rem}
