@charset "UTF-8";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;width:100%;box-sizing:border-box}*{box-sizing:border-box}input,select,textarea{background:#fff!important;color:#000!important}select option{background:#fff;color:#000}input::placeholder{color:#9ca3af!important}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#a78bfa,#7c3aed,#5b21b6);padding:20px;position:relative;overflow:hidden;box-sizing:border-box;margin:0}.login-container:before{content:"";position:absolute;width:600px;height:600px;background:#ffffff1a;border-radius:50%;top:-300px;right:-200px;z-index:0;filter:blur(80px)}.login-container:after{content:"";position:absolute;width:500px;height:500px;background:#ffffff14;border-radius:50%;bottom:-250px;left:-150px;z-index:0;filter:blur(80px)}.login-card{background:#fff;border-radius:24px;box-shadow:0 25px 50px -12px #00000040;padding:48px 40px;width:100%;max-width:420px;min-width:320px;position:relative;z-index:1;animation:slideUp .4s ease-out;box-sizing:border-box;margin:0 auto}.admin-login-card{border-top:4px solid #f59e0b}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:36px}.login-header h1{color:#1f2937;font-size:28px;font-weight:700;margin:0;letter-spacing:-.3px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group label{color:#374151;font-size:14px;font-weight:500;margin-bottom:6px}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:14px;width:18px;height:18px;color:#9ca3af;z-index:1;pointer-events:none}.form-group input{width:100%;padding:12px 16px 12px 44px;border:none;border-radius:12px;font-size:15px;transition:all .2s;outline:none;background:#fff!important;color:#000!important}.form-group input:focus{background:#fff!important;box-shadow:0 0 0 3px #a78bfa1a}.form-group input::placeholder{color:#9ca3af}.error-message{background-color:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:10px;font-size:14px;border:1px solid #fecaca;margin-bottom:4px}.login-button{padding:14px;background:linear-gradient(135deg,#a78bfa,#7c3aed,#5b21b6);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .2s;margin-top:8px;box-shadow:0 4px 14px #7c3aed4d}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #7c3aed66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.admin-button{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 14px #f59e0b4d}.admin-button:hover:not(:disabled){box-shadow:0 6px 20px #f59e0b66}.login-footer{margin-top:28px;text-align:center;font-size:14px;color:#6b7280}.login-footer p{margin:10px 0;line-height:1.6}.link{color:#667eea;text-decoration:none;font-weight:500;transition:color .2s}.link:hover{color:#764ba2;text-decoration:underline}@media(max-width:768px){.login-container{padding:16px}.login-card{padding:40px 32px;max-width:100%;min-width:auto}}@media(max-width:480px){.login-container{padding:12px}.login-card{padding:36px 24px;border-radius:20px}.login-header h1{font-size:26px}.login-form{gap:18px}.form-group input{padding:11px 14px 11px 42px;font-size:14px}.login-button{padding:13px;font-size:14px}}@media(max-width:360px){.login-card{padding:32px 20px}.login-header h1{font-size:24px}}.admin-sidebar{position:fixed;left:0;top:0;height:100vh;background:#1f2937;transition:width .3s ease;z-index:1000;display:flex;flex-direction:column;box-shadow:2px 0 8px #0000001a}.admin-sidebar.open{width:260px}.admin-sidebar.closed{width:70px}.admin-sidebar.closed .logo-text{opacity:0;width:0}.admin-sidebar.closed .sidebar-label{opacity:0;width:0;overflow:hidden}@media(max-width:768px){.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.admin-sidebar{transform:translate(-100%);transition:transform .3s ease}.admin-sidebar.open{transform:translate(0);width:260px}.admin-sidebar.closed{transform:translate(-100%);width:260px}}.admin-header{position:fixed;top:0;left:0;right:0;height:70px;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:999;box-shadow:0 1px 3px #0000001a}.header-left{display:flex;align-items:center;gap:20px;flex:1}.menu-toggle{background:transparent;border:none;color:#374151;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s}.menu-toggle:hover{background:#f3f4f6}.search-bar{position:relative;flex:1;max-width:400px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.search-bar input{width:100%;padding:10px 12px 10px 40px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;background:#f9fafb;transition:all .2s;outline:none}.search-bar input:focus{background:#fff;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.search-bar input::placeholder{color:#9ca3af}.header-right{display:flex;align-items:center;gap:16px}.account-dropdown{position:relative}.account-button{display:flex;align-items:center;gap:10px;padding:8px 12px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:background .2s;color:#374151}.account-button:hover{background:#f3f4f6}.account-avatar{width:36px;height:36px;border-radius:50%;background:#10b981;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.account-name{font-size:14px;font-weight:500;color:#374151}.dropdown-arrow{transition:transform .2s;color:#6b7280}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:0 10px 25px #00000026;min-width:240px;overflow:hidden;animation:slideDown .2s ease-out}.dropdown-header{padding:16px;display:flex;align-items:center;gap:12px;background:#f9fafb}.dropdown-avatar{width:48px;height:48px;border-radius:50%;background:#10b981;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dropdown-user-info{flex:1;min-width:0}.dropdown-user-name{font-size:15px;font-weight:600;color:#1f2937;margin-bottom:4px}.dropdown-user-phone{font-size:13px;color:#6b7280}.dropdown-divider{height:1px;background:#e5e7eb;margin:8px 0}.dropdown-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;text-align:left;cursor:pointer;transition:background .2s;color:#374151;font-size:14px}.dropdown-item:hover{background:#f3f4f6}.dropdown-item.logout{color:#dc2626}.dropdown-item.logout:hover{background:#fee2e2;color:#b91c1c}@media(max-width:768px){.admin-header{padding:0 16px}.search-bar{max-width:200px}.account-name{display:none}}.admin-layout{display:flex;min-height:100vh;background:#f9fafb}.admin-main{flex:1;margin-left:260px;transition:margin-left .3s ease;display:flex;flex-direction:column}.admin-main.sidebar-closed{margin-left:70px}.admin-content{margin-top:70px;padding:24px;flex:1;min-height:calc(100vh - 70px)}@media(max-width:768px){.admin-main,.admin-main.sidebar-open{margin-left:0}.admin-sidebar.open{transform:translate(0)}.admin-sidebar.closed{transform:translate(-100%)}}.sidebar-overlay{display:none}.user-sidebar{position:fixed;left:0;top:0;height:100vh;background:#1f2937;transition:width .3s ease;z-index:1000;display:flex;flex-direction:column;box-shadow:2px 0 8px #0000001a}.user-sidebar.open{width:260px}.user-sidebar.closed{width:70px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.1);min-height:70px}.sidebar-logo{display:flex;align-items:center;overflow:hidden}.logo-text{color:#fff;font-size:18px;font-weight:700;white-space:nowrap;opacity:1;transition:opacity .3s ease}.user-sidebar.closed .logo-text{opacity:0;width:0}.sidebar-toggle{background:transparent;border:none;color:#fff;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s;flex-shrink:0}.sidebar-toggle:hover{background:#ffffff1a}.sidebar-nav{flex:1;padding:16px 0;overflow-y:auto}.sidebar-item{display:flex;align-items:center;padding:12px 16px;margin:4px 12px;color:#ffffffb3;text-decoration:none;border-radius:8px;transition:all .2s;gap:12px;white-space:nowrap}.sidebar-item:hover{background:#ffffff1a;color:#fff}.sidebar-item.active{background:#10b981;color:#fff}.sidebar-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:20px;height:20px}.sidebar-label{font-size:14px;font-weight:500;opacity:1;transition:opacity .3s ease}.user-sidebar.closed .sidebar-label{opacity:0;width:0;overflow:hidden}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media(max-width:768px){.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.user-sidebar{transform:translate(-100%);transition:transform .3s ease}.user-sidebar.open{transform:translate(0);width:260px}.user-sidebar.closed{transform:translate(-100%);width:260px}}.public-header{background:#fff;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100}.header-container{max-width:1200px;margin:0 auto;padding:16px 24px;display:flex;justify-content:space-between;align-items:center}.logo{text-decoration:none;color:#10b981}.logo h1{margin:0;font-size:24px;font-weight:700}.header-nav{display:flex;align-items:center;gap:20px}.nav-link{color:#374151;text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}.nav-link:hover{color:#10b981}.user-menu{display:flex;align-items:center;gap:12px}.user-name{font-size:14px;color:#6b7280}.btn-primary{background:#10b981;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block;transition:all .2s}.btn-logout{background:transparent;border:1px solid #e5e7eb;color:#374151;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.btn-logout:hover{background:#f3f4f6;border-color:#d1d5db}@media(max-width:768px){.header-container{padding:12px 16px}.logo h1{font-size:20px}.header-nav{gap:12px}.user-name{display:none}}.user-layout{display:flex;min-height:100vh;background:#f9fafb}.user-main{flex:1;margin-left:260px;transition:margin-left .3s ease;display:flex;flex-direction:column}.user-main.sidebar-closed{margin-left:70px}.user-content{padding:24px;flex:1;min-height:calc(100vh - 70px)}@media(max-width:768px){.user-main,.user-main.sidebar-open{margin-left:0}.user-sidebar.open{transform:translate(0)}.user-sidebar.closed{transform:translate(-100%)}}.dashboard-page{padding:24px}.dashboard-content{display:flex;flex-direction:column;gap:24px}.dashboard-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.summary-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;display:flex;align-items:flex-start;gap:16px;transition:transform .2s,box-shadow .2s}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.summary-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-card-content{flex:1;min-width:0}.summary-card-label{font-size:14px;color:#6b7280;margin-bottom:8px;font-weight:500}.summary-card-value{font-size:28px;font-weight:700;color:#1f2937;margin-bottom:8px}.summary-card-change{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:500}.summary-card-change.positive{color:#10b981}.summary-card-change.negative{color:#ef4444}.dashboard-charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.dashboard-chart-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.dashboard-chart-card h3{margin:0 0 20px;font-size:18px;font-weight:600;color:#1f2937}.chart-filters{display:flex;gap:8px;margin-bottom:16px}.filter-btn{padding:6px 12px;border:1px solid #e5e7eb;background:#fff;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s}.filter-btn:hover{background:#f9fafb}.dashboard-bottom-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:24px}.dashboard-table-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.table-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.table-card-header h3{margin:0;font-size:18px;font-weight:600;color:#1f2937}.view-all-btn{padding:6px 12px;border:1px solid #e5e7eb;background:#fff;border-radius:6px;font-size:12px;cursor:pointer;color:#3b82f6;transition:all .2s}.view-all-btn:hover{background:#f9fafb;border-color:#3b82f6}.dashboard-table{width:100%;border-collapse:collapse}.dashboard-table thead{background:#f9fafb}.dashboard-table th{padding:12px;text-align:left;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e5e7eb}.dashboard-table td{padding:12px;font-size:14px;color:#1f2937;border-bottom:1px solid #f3f4f6}.dashboard-table tbody tr:hover{background:#f9fafb}.dashboard-table tbody tr:last-child td{border-bottom:none}.price-cell{font-weight:600;color:#10b981}.status-badge.status-pending{background:#fef3c7;color:#92400e}.status-badge.status-confirmed{background:#dbeafe;color:#1e40af}.status-badge.status-completed{background:#d1fae5;color:#065f46}.status-badge.status-cancelled{background:#fee2e2;color:#991b1b}@media(max-width:1200px){.dashboard-charts-row,.dashboard-bottom-row{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-page{padding:16px}.dashboard-summary-cards{grid-template-columns:1fr}.dashboard-chart-card,.dashboard-table-card{padding:16px}}.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.375em;border-bottom-right-radius:.375em}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle,.react-datepicker-popper--header-middle[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper--header-bottom[data-placement^=bottom] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker-popper--header-bottom[data-placement^=top] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select,.react-datepicker__header--middle,.react-datepicker__header--bottom){border-top-right-radius:.3rem}.react-datepicker__header--middle{border-top:1px solid #aeaeae;border-radius:0;margin-top:4px}.react-datepicker__header--bottom{border-bottom:none;border-top:1px solid #aeaeae;border-radius:0 0 .3rem .3rem}.react-datepicker__header-wrapper{position:relative}.react-datepicker__header-wrapper .react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:2px}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__month-select,.react-datepicker__year-select,.react-datepicker__month-year-select{background-color:transparent;border:1px solid #aeaeae;border-radius:.3rem;color:inherit;cursor:pointer;font-family:inherit;font-size:inherit;margin-top:5px;padding:2px 5px}.react-datepicker__month-select:focus-visible,.react-datepicker__year-select:focus-visible,.react-datepicker__month-year-select:focus-visible{outline:auto 1px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.5em;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:5em;margin:2px}.react-datepicker__month{margin:.5em;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:5em;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.375em;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + 1.0625em);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{text-align:center;white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__day-name--disabled,.react-datepicker__day--disabled,.react-datepicker__time-name--disabled{cursor:default;color:#ccc}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.625em;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__children-container{width:17.25em;margin:.5em;padding-right:.25em;padding-left:.25em;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.react-datepicker-popper-offset{margin-top:-.7em}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-secondary{background:#e5e7eb;color:#374151;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.patients-filters{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.filter-btn{padding:8px 16px;border:1px solid #e5e7eb;background:#fff;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.filter-btn:hover{background:#f3f4f6}.filter-btn.active{background:#10b981;color:#fff;border-color:#10b981}.patients-table{width:100%;border-collapse:collapse}.patients-table thead{background:#f9fafb}.patients-table th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.patients-table td{padding:12px 16px;font-size:14px;color:#1f2937;border-bottom:1px solid #f3f4f6}.patients-table tbody tr:hover{background:#f9fafb}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding:16px}.pagination-btn{padding:8px 16px;border:1px solid #e5e7eb;background:#fff;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#d1d5db}.pagination-info{font-size:14px;color:#6b7280}@media(max-width:768px){.page-header{flex-direction:column;gap:16px}.patients-filters{flex-direction:column}.search-form{min-width:100%}.form-row{grid-template-columns:1fr}.table-container{overflow-x:scroll}.modal-content{max-width:100%;margin:0}}.booking-modal{max-width:600px}.service-select{width:100%;padding:10px;border:2px solid #000000;border-radius:6px;font-size:14px;background:#fff!important;color:#000!important}.selected-services-form{margin:16px 0}.selected-services-form h3{font-size:14px;font-weight:600;color:#1f2937;margin-bottom:12px}.selected-service-form-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.selected-service-form-item span{font-size:14px;color:#000!important;font-weight:500}.remove-service-form-btn{background:#fee2e2;color:#dc2626;border:none;width:24px;height:24px;border-radius:50%;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-weight:700}.time-select{padding:10px;border:2px solid #000000;border-radius:6px;font-size:14px;background:#fff!important;color:#000!important}.time-separator{font-size:18px;font-weight:600;color:#000}.date-picker-input{width:100%;padding:10px;border:2px solid #000000;border-radius:6px;font-size:14px;background:#fff!important;color:#000!important}.react-datepicker__input-container input{width:100%;padding:10px;border:2px solid #000000;border-radius:6px;font-size:14px;outline:none;transition:all .2s;font-family:inherit;background:#fff!important;color:#000!important;cursor:pointer}.appointments-list-compact{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.appointment-item-compact{padding:16px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;cursor:pointer;transition:all .2s}.appointment-item-compact:hover{background:#f3f4f6;border-color:#10b981;transform:translate(4px)}.appointment-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.appointment-date-time-compact{display:flex;flex-direction:column;gap:4px}.appointment-date-text{font-size:14px;font-weight:600;color:#1f2937}.appointment-time-text{font-size:12px;color:#6b7280}.appointment-services-compact{font-size:13px;color:#374151;margin-bottom:4px}.appointment-price-compact{font-size:14px;font-weight:600;color:#10b981}.service-detail-item{padding:12px;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.service-detail-name{font-size:14px;font-weight:600;color:#1f2937;margin-bottom:4px}.service-detail-info{display:flex;gap:8px;align-items:center}.service-price{font-size:13px;font-weight:600;color:#10b981}.detail-totals{margin-top:16px;padding-top:16px;border-top:2px solid #e5e7eb}.filter-section{display:flex;flex-direction:column;gap:16px}.date-filters{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.date-filter-group{display:flex;flex-direction:column;gap:6px}.date-filter-group label{font-size:12px;font-weight:500;color:#6b7280}.date-filter-input{padding:8px 12px;border:2px solid #000000;border-radius:6px;font-size:14px;background:#fff!important;color:#000!important;min-width:150px;width:100%}.date-filter-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.react-datepicker__input-container input{width:100%;padding:8px 12px;border:2px solid #000000;border-radius:6px;font-size:14px;outline:none;transition:all .2s;font-family:inherit;background:#fff!important;color:#000!important;cursor:pointer}.react-datepicker__navigation:hover *:before{border-color:#000}.react-datepicker__input-container:after{content:"";position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none}.btn-clear-filter{background:#fee2e2;color:#dc2626;border:1px solid #fecaca;padding:8px 12px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;height:38px}.btn-clear-filter:hover{background:#fecaca;border-color:#fca5a5}.appointments-table{width:100%;border-collapse:collapse}.appointments-table thead{background:#f9fafb}.appointments-table th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.appointments-table td{padding:12px 16px;font-size:14px;color:#1f2937;border-bottom:1px solid #f3f4f6}.appointment-row{cursor:pointer;transition:all .2s}.appointment-row:hover{background:#f9fafb}.patient-info{display:flex;flex-direction:column;gap:4px}.patient-name{font-weight:600;color:#1f2937}.patient-phone{font-size:12px;color:#6b7280}.service-info{display:flex;flex-direction:column;gap:4px}.service-name{font-weight:500;color:#1f2937}.service-duration{font-size:12px;color:#6b7280}.date-info,.time-info{font-weight:500;color:#1f2937}.price-info{font-weight:600;color:#10b981}.status-pending{background:#fef3c7;color:#92400e}.status-confirmed{background:#dbeafe;color:#1e40af}.status-completed{background:#d1fae5;color:#065f46}.status-cancelled{background:#fee2e2;color:#991b1b}.btn-danger{background:#dc2626;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.btn-success{background:#10b981;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-success:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-success:disabled{opacity:.6;cursor:not-allowed}.actions-cell{cursor:default!important}.action-buttons{display:flex;gap:6px;align-items:center}.btn-icon{background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#6b7280}.btn-icon:hover{background:#f3f4f6}.btn-icon.btn-confirm{color:#10b981}.btn-icon.btn-confirm:hover{background:#d1fae5;color:#059669}.btn-icon.btn-complete{color:#3b82f6}.btn-icon.btn-complete:hover{background:#dbeafe;color:#2563eb}.btn-icon.btn-edit{color:#f59e0b}.btn-icon.btn-edit:hover{background:#fef3c7;color:#d97706}.btn-icon.btn-cancel{color:#ef4444}.btn-icon.btn-cancel:hover{background:#fee2e2;color:#dc2626}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding:20px 0}.pagination-btn{padding:8px 16px;border:1px solid #e5e7eb;background:#fff;color:#374151;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f9fafb;border-color:#10b981;color:#10b981}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:14px;color:#6b7280;font-weight:500}.selected-services-form{margin-top:12px;display:flex;flex-direction:column;gap:8px}.selected-service-form-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;color:#000!important}.selected-service-form-item span{color:#000!important}.remove-service-form-btn{background:#fee2e2;color:#dc2626;border:none;width:24px;height:24px;border-radius:50%;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.remove-service-form-btn:hover{background:#fecaca;transform:scale(1.1)}.form-hint{margin-top:8px;font-size:12px;color:#9ca3af;font-style:italic}.modal-form .form-group input,.modal-form .form-group select,.modal-form .form-group textarea{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;outline:none;transition:all .2s;font-family:inherit;background:#fff!important;color:#000!important}.modal-form .form-group select option{background:#fff;color:#000}.modal-form .form-group input:focus,.modal-form .form-group select:focus,.modal-form .form-group textarea:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.services-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}@media(max-width:768px){.detail-grid{grid-template-columns:1fr}.appointments-table{font-size:12px}.appointments-table th,.appointments-table td{padding:8px 12px}.patient-name,.service-name{font-size:13px}.patient-phone,.service-duration{font-size:11px}}.services-filters{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.search-form{display:flex;flex:1;min-width:300px;gap:8px}.search-input{flex:1;padding:10px 16px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;outline:none;transition:all .2s;background:#fff!important;color:#000!important}.search-input:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.btn-search{background:#10b981;color:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-search:hover{background:#059669}.filter-buttons{display:flex;gap:8px}.filter-btn{padding:8px 16px;border:1px solid #bfdbfe;background:#dbeafe;color:#1f2937;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s;font-weight:500}.error-message{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.loading{text-align:center;padding:40px;color:#6b7280}.table-container{overflow-x:auto;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.services-table{width:100%;border-collapse:collapse}.services-table thead{background:#f9fafb}.services-table th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.services-table td{padding:12px 16px;font-size:14px;color:#1f2937;border-bottom:1px solid #f3f4f6}.services-table tbody tr:hover{background:#f9fafb}.empty-state{text-align:center;color:#6b7280;padding:40px!important}.service-image-cell{width:80px;height:60px;display:flex;align-items:center;justify-content:center}.service-image-cell img{width:100%;height:100%;object-fit:cover;border-radius:6px}.no-image-placeholder{width:100%;height:100%;background:#f3f4f6;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#9ca3af}.service-name-cell{font-weight:600;color:#1f2937}.service-description-cell{color:#6b7280;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.service-duration-cell{font-weight:500;color:#1f2937}.service-price-cell{font-weight:600;color:#10b981}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.action-buttons{display:flex;gap:8px}.btn-icon{background:transparent;border:1px solid #e5e7eb;padding:6px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s}.btn-icon:hover{background:#f3f4f6;border-color:#d1d5db}.btn-icon.delete:hover{background:#fee2e2;border-color:#fecaca;color:#dc2626}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-content::-webkit-scrollbar{width:0px;background:transparent}.modal-content{scrollbar-width:none;-ms-overflow-style:none}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:20px;font-weight:700;color:#1f2937}.modal-close{background:transparent;border:none;font-size:28px;color:#6b7280;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#374151}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;outline:none;transition:all .2s;font-family:inherit;background:#fff!important;color:#000!important}.file-input{padding:8px!important}.form-hint{display:block;margin-top:6px;font-size:12px;color:#6b7280}.service-name-display{padding:10px 12px;background:#f9fafb;border-radius:8px;font-weight:500;color:#1f2937}.image-preview{width:100%;max-height:300px;border-radius:8px;overflow:hidden;background:#f3f4f6;border:2px dashed #e5e7eb}.image-preview img{width:100%;height:auto;display:block}.no-image-placeholder-large{width:100%;min-height:200px;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9ca3af;gap:12px;padding:40px}.no-image-placeholder-large svg{color:#d1d5db}.no-image-placeholder-large p{margin:0;font-size:14px;color:#6b7280}.checkbox-group label{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto;cursor:pointer}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}@media(max-width:768px){.services-filters{flex-direction:column}.search-form{min-width:100%}.form-row{grid-template-columns:1fr}.table-container{overflow-x:scroll}.modal-content{max-width:100%;margin:0}.service-description-cell{max-width:150px}}.detail-content{padding:24px;max-height:60vh;overflow-y:auto}.detail-content::-webkit-scrollbar,.modal-content::-webkit-scrollbar{width:0px;background:transparent}.detail-content,.modal-content{scrollbar-width:none;-ms-overflow-style:none}.service-detail-image{width:100%;max-width:400px;margin:0 auto;border-radius:8px;overflow:hidden}.service-detail-image img{width:100%;height:auto;display:block}.actions-cell{position:relative}@media(max-width:768px){.detail-grid{grid-template-columns:1fr}}.dashboard-page{width:100%}.profile-content{max-width:800px}.profile-card{background:#fff;border-radius:12px;padding:32px;box-shadow:0 1px 3px #0000001a}.profile-header{display:flex;align-items:center;gap:20px;padding-bottom:24px;border-bottom:1px solid #e5e7eb;margin-bottom:24px}.profile-avatar{width:80px;height:80px;border-radius:50%;background:#10b981;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-name-section{flex:1}.profile-name-section h2{margin:0 0 4px;font-size:24px;font-weight:700;color:#1f2937}.profile-phone{margin:0;font-size:14px;color:#6b7280}.btn-edit{background:#10b981;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-edit:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.profile-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group label{font-size:14px;font-weight:500;color:#374151}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;outline:none;transition:all .2s;font-family:inherit;background:#fff!important;color:#000!important}.form-group select option{background:#fff;color:#000}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px;padding-top:20px;border-top:1px solid #e5e7eb}.btn-cancel{background:#e5e7eb;color:#374151;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#d1d5db}.btn-save{background:#10b981;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-save:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-save:disabled{opacity:.6;cursor:not-allowed}.profile-info{display:flex;flex-direction:column}.info-section{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.info-item label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.info-item>div{font-size:15px;font-weight:500;color:#1f2937}.error-message{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;border:1px solid #fecaca;display:flex;align-items:center;gap:8px;animation:slideDown .3s ease-out}.error-message strong{font-weight:600}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.profile-header{flex-direction:column;text-align:center}.form-row,.info-section{grid-template-columns:1fr}}.my-appointments-page{width:100%}.page-header{margin-bottom:24px}.page-header h1{font-size:28px;font-weight:700;color:#1f2937;margin:0 0 8px}.page-header p{font-size:14px;color:#6b7280;margin:0}.appointments-filters{margin-bottom:20px}.filter-buttons{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{padding:8px 16px;border:1px solid #a7d9f6;background:#dbeafe;color:#1f2937;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s;font-weight:500}.filter-btn:hover{background:#bfdbfe;border-color:#93c5fd}.filter-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.appointments-list{display:flex;flex-direction:column;gap:16px}.appointment-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .2s;border:1px solid #e5e7eb}.appointment-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:#10b981}.appointment-card-content{padding:20px;display:flex;justify-content:space-between;align-items:center;gap:20px}.appointment-main-info{flex:1;display:flex;gap:24px;align-items:center}.appointment-date-time{min-width:150px}.appointment-date-text{font-size:16px;font-weight:600;color:#1f2937;margin-bottom:4px}.appointment-time-text{font-size:14px;color:#6b7280}.appointment-service-info{flex:1}.appointment-service-name{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 8px}.appointment-service-details{display:flex;align-items:center;gap:8px;font-size:14px;color:#6b7280}.separator{color:#d1d5db}.appointment-service-details .price{color:#10b981;font-weight:600}.appointment-status-section{display:flex;flex-direction:column;align-items:flex-end;gap:12px}.status-badge{display:inline-block;padding:5px 10px;border-radius:5px;font-size:12px;font-weight:600;color:#fff}.status-pending{background-color:#ffc107;color:#343a40}.status-confirmed{background-color:#17a2b8}.status-completed{background-color:#28a745}.status-cancelled{background-color:#dc3545}.btn-cancel-small{background:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel-small:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.btn-cancel-small:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;padding:30px;border-radius:10px;box-shadow:0 5px 15px #0000004d;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;position:relative}.modal-content::-webkit-scrollbar,.detail-content::-webkit-scrollbar{width:0px;background:transparent}.modal-content,.detail-content{scrollbar-width:none;-ms-overflow-style:none}.detail-modal{max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;color:#343a40;font-size:24px}.detail-content{padding:0}.detail-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.detail-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.detail-section h3{margin:0 0 16px;font-size:16px;font-weight:600;color:#1f2937}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.detail-item{display:flex;flex-direction:column;gap:6px}.detail-item label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.detail-item>div{font-size:14px;color:#1f2937;font-weight:500}.price-highlight{font-size:18px!important;font-weight:700!important;color:#10b981!important}.notes-content{background:#f9fafb;padding:12px 16px;border-radius:8px;font-size:14px;color:#374151;line-height:1.6;white-space:pre-wrap}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:25px;padding-top:20px;border-top:1px solid #e5e7eb}.btn-secondary{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:5px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#5a6268}.btn-danger{background:#dc3545;color:#fff;border:none;padding:10px 20px;border-radius:5px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-danger:hover:not(:disabled){background:#c82333}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.services-list-detail{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.service-detail-item{padding:12px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.service-detail-name{font-size:15px;font-weight:600;color:#1f2937;margin-bottom:6px}.service-detail-info{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280}.service-detail-info .separator{color:#d1d5db}.service-detail-info .service-price{color:#10b981;font-weight:600}.detail-totals{margin-top:16px;padding-top:16px;border-top:2px solid #e5e7eb;display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:768px){.appointment-card-content{flex-direction:column;align-items:flex-start}.appointment-main-info{flex-direction:column;align-items:flex-start;gap:12px}.appointment-status-section{flex-direction:row;align-items:center;width:100%;justify-content:space-between}.detail-grid{grid-template-columns:1fr}.modal-content{padding:20px}}.public-footer{background:#1f2937;color:#e5e7eb;padding:60px 24px 24px;margin-top:60px}.footer-container{max-width:1200px;margin:0 auto}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px;margin-bottom:40px}.footer-section{display:flex;flex-direction:column;gap:16px}.footer-title{font-size:20px;font-weight:700;color:#fff;margin:0 0 12px}.footer-description{font-size:14px;color:#9ca3af;line-height:1.6;margin:0}.footer-section-title{font-size:16px;font-weight:600;color:#fff;margin:0 0 12px}.footer-contact-item{display:flex;align-items:center;gap:12px;color:#d1d5db;font-size:14px;margin-bottom:10px}.footer-contact-item svg{flex-shrink:0;color:#10b981}.footer-links{display:flex;flex-direction:column;gap:10px}.footer-link{color:#d1d5db;text-decoration:none;font-size:14px;transition:color .2s}.footer-link:hover{color:#10b981}.footer-hours{display:flex;flex-direction:column;gap:10px}.footer-hour-item{display:flex;justify-content:space-between;font-size:14px;color:#d1d5db}.footer-hour-item .day{font-weight:500}.footer-hour-item .time{color:#9ca3af}.footer-bottom{border-top:1px solid #374151;padding-top:24px;text-align:center}.footer-copyright{font-size:14px;color:#9ca3af;margin:0}@media(max-width:768px){.public-footer{padding:40px 20px 20px}.footer-content{grid-template-columns:1fr;gap:32px}.footer-hour-item{flex-direction:column;gap:4px}}.service-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:all .3s;cursor:pointer;border:1px solid #e5e7eb;display:flex;flex-direction:column}.service-card-image{width:100%;height:200px;overflow:hidden;background:#f3f4f6;position:relative}.service-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.service-card:hover .service-card-image img{transform:scale(1.05)}.service-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026;border-color:#10b981}.service-card-content{padding:24px;display:flex;flex-direction:column;flex:1}.service-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:12px}.service-card-title{margin:0;font-size:20px;font-weight:700;color:#1f2937;flex:1}.service-card-price{font-size:20px;font-weight:700;color:#10b981;white-space:nowrap}.service-card-description{color:#6b7280;font-size:14px;line-height:1.6;margin:0 0 16px;flex:1}.service-card-info{display:flex;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f3f4f6}.service-info-item{display:flex;align-items:center;gap:6px;font-size:14px;color:#6b7280}.service-info-item svg{color:#9ca3af}.service-card-actions{display:flex;gap:12px;margin-top:auto}.btn-view-details{flex:1;background:#fff;border:2px solid #10b981;color:#10b981;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-view-details:hover{background:#f0fdf4}.btn-book-now{flex:1;background:#10b981;border:none;color:#fff;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-book-now:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}@media(max-width:768px){.service-card-content{padding:20px}.service-card-header{flex-direction:column;align-items:flex-start}.service-card-title,.service-card-price{font-size:18px}.service-card-actions{flex-direction:column}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.service-detail-modal{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a;animation:slideUp .3s ease-out}.service-detail-modal::-webkit-scrollbar{width:0px;background:transparent}.service-detail-modal{scrollbar-width:none;-ms-overflow-style:none}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:24px;font-weight:700;color:#1f2937}.modal-close{background:transparent;border:none;font-size:32px;color:#6b7280;cursor:pointer;line-height:1;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-body{padding:24px}.service-detail-image{width:100%;height:300px;margin-bottom:24px;border-radius:12px;overflow:hidden;background:#f3f4f6}.service-detail-image img{width:100%;height:100%;object-fit:cover}.service-detail-price{font-size:32px;font-weight:700;color:#10b981;margin-bottom:24px;text-align:center;padding:20px;background:#f0fdf4;border-radius:12px}.service-detail-section{margin-bottom:24px}.service-detail-section h3{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 12px}.service-detail-section p{color:#6b7280;font-size:15px;line-height:1.7;margin:0}.service-detail-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:20px;background:#f9fafb;border-radius:12px}.info-item{display:flex;flex-direction:column;gap:6px}.info-label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:18px;font-weight:600;color:#1f2937}.info-value.price{color:#10b981;font-size:20px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid #e5e7eb}.btn-secondary{background:#e5e7eb;color:#374151;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#d1d5db}.btn-primary{background:#10b981;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}@media(max-width:768px){.service-detail-modal{max-width:100%;margin:0;border-radius:16px 16px 0 0}.service-detail-info-grid{grid-template-columns:1fr}}.home-page{min-height:100vh;background:#f9fafb}.hero-section{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:80px 24px;text-align:center}.hero-content{max-width:800px;margin:0 auto}.hero-title{font-size:48px;font-weight:700;margin:0 0 16px;line-height:1.2}.hero-subtitle{font-size:20px;margin:0;opacity:.95}.doctor-services-section{padding:60px 24px;background:#fff}.doctor-services-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:40px;align-items:start}.doctor-info-column{position:sticky;top:20px}.doctor-card{display:flex;flex-direction:column;align-items:center;gap:24px;background:#f9fafb;padding:40px;border-radius:16px;box-shadow:0 4px 12px #0000000d}.doctor-image-wrapper{flex-shrink:0}.doctor-image-placeholder{width:180px;height:180px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 16px #10b9814d;overflow:hidden}.doctor-image-placeholder img{width:100%;height:100%;object-fit:cover;border-radius:50%}.doctor-info{width:100%;text-align:center}.doctor-name{font-size:32px;font-weight:700;color:#1f2937;margin:0 0 8px}.doctor-specialization{font-size:18px;color:#10b981;font-weight:600;margin:0 0 24px}.doctor-details{display:flex;flex-direction:column;gap:16px;align-items:flex-start}.doctor-detail-item{display:flex;align-items:center;gap:12px;color:#6b7280;font-size:15px}.doctor-detail-item svg{flex-shrink:0;color:#10b981}.doctor-detail-item span{line-height:1.5}.doctor-address-link{color:#6b7280;text-decoration:none;line-height:1.5;transition:color .2s}.doctor-address-link:hover{color:#10b981;text-decoration:underline}.expandable-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.expandable-content.expanded{max-height:1000px;transition:max-height .5s ease-in}.expand-toggle{margin-top:16px;padding:0;background:none;border:none;color:#10b981;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:color .2s}.expand-toggle:hover{color:#059669;text-decoration:underline}.expand-toggle svg{transition:transform .3s ease}.expand-toggle svg.rotated{transform:rotate(180deg)}.doctor-specialties{margin-top:32px;padding-top:32px;border-top:1px solid #e5e7eb}.specialties-title{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 16px}.specialties-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.specialties-list li{color:#6b7280;font-size:15px;line-height:1.6;padding-left:24px;position:relative}.specialties-list li:before{content:"•";color:#10b981;font-weight:700;position:absolute;left:0;font-size:20px}.services-column{width:100%}.container{max-width:1400px;margin:0 auto}.section-title{font-size:36px;font-weight:700;color:#1f2937;text-align:left;margin:0 0 12px}.section-subtitle{font-size:18px;color:#6b7280;text-align:left;margin:0 0 32px}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.loading,.empty-state{text-align:center;padding:60px 20px;color:#6b7280;font-size:16px}@media(max-width:1024px){.doctor-services-layout{grid-template-columns:1fr;gap:40px}.doctor-info-column{position:static}.section-title,.section-subtitle{text-align:center}}@media(max-width:768px){.hero-section{padding:60px 20px}.hero-title{font-size:32px}.hero-subtitle{font-size:16px}.doctor-services-section{padding:40px 16px}.doctor-services-layout{gap:30px}.doctor-card{padding:30px 20px;gap:24px}.doctor-image-placeholder{width:150px;height:150px}.doctor-name{font-size:26px}.doctor-specialization{font-size:16px}.doctor-details{align-items:center}.doctor-detail-item{justify-content:center}.section-title{font-size:28px}.section-subtitle{font-size:16px}.services-grid{grid-template-columns:1fr;gap:20px}}.booking-page{min-height:100vh;background:#f9fafb}.booking-container{max-width:1000px;margin:0 auto;padding:40px 24px}.booking-content{display:grid;grid-template-columns:1fr 400px;gap:32px}.booking-form-section{background:#fff;border-radius:12px;padding:32px;box-shadow:0 1px 3px #0000001a;border:2px solid #000000}.booking-form-section h1{font-size:28px;font-weight:700;color:#000;margin:0 0 24px}.booking-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#000}.form-group input,.form-group textarea{padding:12px 16px;border:2px solid #000000;border-radius:8px;font-size:15px;outline:none;transition:all .2s;font-family:inherit;background:#fff;color:#000!important}.form-group input:focus,.form-group textarea:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.form-group textarea{resize:vertical}.btn-submit{background:#10b981;color:#fff;border:2px solid #000000;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.btn-submit:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-submit:disabled{opacity:.6;cursor:not-allowed;border-color:#6b7280}.booking-summary{position:sticky;top:100px;height:fit-content}.summary-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border:2px solid #000000}.summary-card h2{font-size:20px;font-weight:700;color:#000;margin:0 0 20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.summary-item{margin-bottom:16px}.summary-item:last-child{margin-bottom:0}.summary-label{font-size:12px;font-weight:500;color:#000;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.summary-value{font-size:15px;font-weight:600;color:#000}.summary-value.description{font-weight:400;color:#6b7280;line-height:1.6}.summary-value.price{font-size:24px;font-weight:700;color:#10b981}.error-message{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.loading{text-align:center;padding:60px 20px;color:#6b7280;font-size:16px}.service-select{padding:12px 16px;border:2px solid #000000;border-radius:8px;font-size:15px;outline:none;transition:all .2s;font-family:inherit;background:#fff;cursor:pointer;color:#000!important}.service-select option{color:#000;background:#fff}.service-select:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.date-picker-input{width:100%;padding:12px 16px;border:2px solid #000000;border-radius:8px;font-size:15px;outline:none;transition:all .2s;font-family:inherit;background:#fff!important;color:#000!important;cursor:pointer}.date-picker-input:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.react-datepicker-wrapper{width:100%}.react-datepicker__input-container input{width:100%;padding:12px 16px;border:2px solid #000000;border-radius:8px;font-size:15px;outline:none;transition:all .2s;font-family:inherit;background:#fff!important;color:#000!important;cursor:pointer}.react-datepicker__input-container input:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.react-datepicker__calendar-icon{filter:invert(0);color:#000}.react-datepicker__input-container .react-datepicker__calendar-icon{fill:#000;stroke:#000}.react-datepicker{border:2px solid #000000;border-radius:8px;font-family:inherit}.react-datepicker__header{background-color:#fff;border-bottom:1px solid #e5e7eb;border-radius:8px 8px 0 0}.react-datepicker__current-month,.react-datepicker__day-name{color:#000;font-weight:600}.react-datepicker__day{color:#000}.react-datepicker__day:hover{background-color:#f3f4f6;color:#000}.react-datepicker__day--selected{background-color:#10b981;color:#fff}.react-datepicker__day--selected:hover{background-color:#059669;color:#fff}.react-datepicker__day--keyboard-selected{background-color:#d1fae5;color:#000}.react-datepicker__day--disabled{color:#d1d5db;cursor:not-allowed}.react-datepicker__navigation-icon:before{border-color:#000}.react-datepicker__navigation:hover *:before{border-color:#10b981}.react-datepicker__input-container{position:relative}.react-datepicker__input-container:after{content:"";position:absolute;right:12px;top:50%;transform:translateY(-50%);width:20px;height:20px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23000000'%3E%3Cpath d='M19 4h-1V2h-2v2H8V2H6v2H5c-1.11 0-1.99.9-1.99 2L3 20c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm0 16H5V10h14v10zm0-12H5V6h14v2z'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;pointer-events:none;z-index:1}.time-selectors{display:flex;align-items:center;gap:8px}.time-select{padding:12px 16px;border:2px solid #000000;border-radius:8px;font-size:15px;outline:none;transition:all .2s;font-family:inherit;background:#fff!important;color:#000!important;cursor:pointer;min-width:80px}.time-select option{background:#fff;color:#000}.time-select:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.time-separator{font-size:20px;font-weight:600;color:#000}.selected-services{margin-bottom:20px;padding:16px;background:#f9fafb;border-radius:8px;border:2px solid #000000}.selected-services h3{font-size:16px;font-weight:600;color:#000;margin:0 0 12px}.selected-services-list{display:flex;flex-direction:column;gap:8px}.selected-service-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#fff;border-radius:6px;border:2px solid #000000}.service-info{flex:1}.service-name{font-size:14px;font-weight:600;color:#000;margin-bottom:4px}.service-details{font-size:12px;color:#000}.remove-service-btn{background:#fee2e2;color:#dc2626;border:none;width:28px;height:28px;border-radius:50%;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;font-weight:700}.remove-service-btn:hover{background:#fecaca;transform:scale(1.1)}.no-services-selected{text-align:center;padding:40px 20px;color:#000;font-size:14px}.selected-services-summary{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.summary-appointment-details{margin-top:20px;padding-top:20px;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:16px}.summary-detail-item{display:flex;flex-direction:column;gap:4px}.summary-detail-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.summary-detail-value{font-size:14px;color:#000;font-weight:500}.summary-detail-value.notes{font-size:13px;color:#374151;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.summary-service-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f3f4f6}.summary-service-item:last-child{border-bottom:none}.summary-service-name{font-size:14px;color:#000;flex:1}.summary-service-price{font-size:14px;font-weight:600;color:#10b981}.summary-totals{margin-top:16px;padding-top:16px;border-top:2px solid #e5e7eb}.summary-item.total{margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}@media(max-width:968px){.booking-content{grid-template-columns:1fr}.booking-summary{position:static}}@media(max-width:768px){.booking-container{padding:24px 16px}.booking-form-section{padding:24px}.booking-form-section h1{font-size:24px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.dashboard{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.dashboard h1{font-size:32px;margin-bottom:16px}.dashboard p{font-size:18px;margin-bottom:24px}.dashboard button{padding:12px 24px;background:#fff;color:#667eea;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.dashboard button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}
