:root{--bg:#f4f7fb;--bg-card:#fff;--bg-elevated:#fff;--border:#e6ecf3;--border-strong:#d4dde8;--text:#1a2a3a;--text-muted:#5b6b7d;--text-soft:#8696aa;--primary:#4f7cf2;--primary-hover:#3d6ae0;--primary-soft:#eaf1ff;--accent:#7bb8c6;--success:#3fb27f;--success-soft:#e3f7ec;--warning:#e7a23e;--danger:#e36464;--danger-soft:#fdecec;--shadow-sm:0 1px 2px #1428500a, 0 1px 3px #1428500f;--shadow:0 6px 16px #1428500f, 0 2px 4px #1428500a;--shadow-lg:0 24px 60px #1428501f, 0 8px 16px #1428500f;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:22px;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:var(--font);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(#f1f5fb 0%,#f6f9fd 100%);font-size:14px;line-height:1.5}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:14px}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{color:var(--text);margin:0;font-weight:700}p{margin:0}.btn{border-radius:var(--radius-sm);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;line-height:1.2;transition:all .18s;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 14px #4f7cf247}.btn-secondary{border-color:var(--border-strong);color:var(--text);background:#fff}.btn-secondary:hover:not(:disabled){background:#f7f9fc;border-color:#b8c5d5}.btn-ghost{color:var(--text-muted);background:0 0}.btn-ghost:hover:not(:disabled){color:var(--text);background:#eef2f8}.btn-danger{color:var(--danger);background:#fff;border-color:#f3c5c5}.btn-danger:hover:not(:disabled){background:var(--danger-soft);border-color:var(--danger)}.btn-sm{padding:6px 12px;font-size:13px}.btn-icon{border-radius:8px;width:34px;height:34px;padding:0}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--text-muted);font-size:13px;font-weight:600}.input,.select,.textarea{border-radius:var(--radius-sm);border:1px solid var(--border-strong);width:100%;color:var(--text);background:#fff;outline:none;padding:10px 14px;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f7cf226}.textarea{resize:vertical;min-height:80px}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:22px}.badge{border-radius:999px;align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-admin{color:#4257d6;background:#eef1ff}.badge-doctor{color:#2f8d63;background:#e6f4ee}.table{border-collapse:separate;border-spacing:0;width:100%;font-size:14px}.table th,.table td{text-align:left;border-bottom:1px solid var(--border);padding:12px 14px}.table th{text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft);background:#f8fafd;font-size:12px;font-weight:600}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#f8fafd}.row{align-items:center;gap:12px;display:flex}.row-between{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.stack{flex-direction:column;gap:12px;display:flex}.empty{text-align:center;color:var(--text-soft);padding:36px 16px}.error-text{color:var(--danger);font-size:13px}.muted{color:var(--text-muted);font-size:13px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.spinner-dark{border-color:#4f7cf233;border-top-color:var(--primary)}.page{width:100%;max-width:1200px;margin:0 auto}.login-shell{background:radial-gradient(circle at 10% 0,#7bb8c62e,#0000 50%),radial-gradient(circle at 90% 100%,#4f7cf22e,#0000 55%),linear-gradient(#f1f5fb,#f7faff);place-items:center;min-height:100vh;padding:24px;display:grid}.login-wrap{border-radius:var(--radius-xl);width:min(960px,100%);box-shadow:var(--shadow-lg);background:#fff;grid-template-columns:1.05fr 1fr;min-height:560px;display:grid;overflow:hidden}.login-illustration{color:#fff;background:linear-gradient(160deg,#4f7cf2 0%,#7bb8c6 100%);align-items:center;padding:44px 38px;display:flex;position:relative;overflow:hidden}.login-illustration:before{content:"";background:#ffffff14;border-radius:50%;width:320px;height:320px;position:absolute;top:-60px;right:-80px}.login-illustration:after{content:"";background:#ffffff0f;border-radius:50%;width:200px;height:200px;position:absolute;bottom:-40px;left:-50px}.ill-content{z-index:1;position:relative}.ill-logo{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff2e;border-radius:18px;place-items:center;width:64px;height:64px;margin-bottom:22px;display:grid}.login-illustration h1{color:#fff;letter-spacing:-.02em;margin:0 0 10px;font-size:32px}.login-illustration p{color:#ffffffdb;max-width:320px;margin-bottom:24px;font-size:15px;line-height:1.55}.ill-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.ill-list li{color:#ffffffeb;padding-left:24px;font-size:14px;position:relative}.ill-list li:before{content:"";background:#ffffffd9;border-radius:50%;width:8px;height:8px;position:absolute;top:9px;left:0}.login-card{align-items:center;padding:50px 44px;display:flex}.login-card-inner{flex-direction:column;gap:22px;width:100%;display:flex}.login-head h2{letter-spacing:-.01em;margin:0 0 6px;font-size:26px}.login-hint{border-top:1px dashed var(--border);color:var(--text-soft);flex-direction:column;gap:4px;padding-top:16px;font-size:12px;display:flex}.login-hint code{border:1px solid var(--border);color:var(--text);background:#f4f7fb;border-radius:6px;align-self:flex-start;padding:4px 8px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px}@media (width<=820px){.login-wrap{min-height:unset;grid-template-columns:1fr}.login-illustration{padding:32px 28px}.login-illustration h1{font-size:26px}.login-card{padding:32px 26px}}.app-shell{background:linear-gradient(#eef3fa 0%,#f5f8fc 100%);min-height:100vh;display:flex}.sidebar{border-right:1px solid var(--border);background:#fff;flex-direction:column;width:260px;height:100vh;padding:22px 16px;display:flex;position:sticky;top:0}.brand{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:6px 10px 22px;display:flex}.brand-mark{color:#fff;background:linear-gradient(135deg,#4f7cf2 0%,#7bb8c6 100%);border-radius:12px;place-items:center;width:42px;height:42px;display:grid;box-shadow:0 8px 18px #4f7cf247}.brand-text{flex-direction:column;display:flex}.brand-title{color:var(--text);letter-spacing:-.01em;font-size:16px;font-weight:700}.brand-sub{color:var(--text-soft);text-transform:uppercase;letter-spacing:.08em;font-size:11px}.nav{flex-direction:column;flex:1;gap:4px;margin-top:18px;display:flex}.nav-link{color:var(--text-muted);border-radius:10px;align-items:center;gap:12px;padding:11px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-link:hover{color:var(--text);background:#f4f7fc;text-decoration:none}.nav-link.active{background:var(--primary-soft);color:var(--primary);font-weight:600}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding-top:14px;display:flex}.user-card{align-items:center;gap:10px;padding:6px 8px;display:flex}.avatar{color:#fff;letter-spacing:.02em;background:linear-gradient(135deg,#4f7cf2,#7bb8c6);border-radius:50%;flex-shrink:0;place-items:center;width:38px;height:38px;font-size:13px;font-weight:700;display:grid}.user-meta{flex-direction:column;min-width:0;display:flex}.user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;overflow:hidden}.user-role{margin-top:2px}.logout-btn{justify-content:flex-start;width:100%}.main{flex:1;min-width:0;padding:32px 36px}@media (width<=920px){.app-shell{flex-direction:column}.sidebar{flex-flow:wrap;align-items:center;gap:12px;width:100%;height:auto;padding:12px 16px;position:static}.brand{border-bottom:none;margin-right:auto;padding:0}.nav{flex-direction:row;flex:none;gap:6px;margin:0}.nav-link{padding:8px 12px}.nav-link span{display:none}.sidebar-footer{border-top:none;flex-direction:row;align-items:center;gap:12px;padding-top:0}.user-card{padding:0}.user-meta,.logout-btn span{display:none}.main{padding:22px 18px}}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#141e326b;place-items:center;padding:16px;animation:.18s fadeIn;display:grid;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-height:90vh;animation:.2s cubic-bezier(.16,1,.3,1) scaleIn;overflow:auto}.modal-sm{max-width:380px}.modal-md{max-width:520px}.modal-lg{max-width:720px}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 22px 14px;display:flex}.modal-head h3{letter-spacing:-.01em;margin:0;font-size:17px;font-weight:700}.modal-body{padding:20px 22px 22px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px;display:flex}.page-title{letter-spacing:-.01em;margin:0 0 4px;font-size:24px}.table-wrap{overflow-x:auto}.users-table th:first-child,.users-table td:first-child{padding-left:22px}.users-table th:last-child,.users-table td:last-child{padding-right:22px}.user-cell{align-items:center;gap:12px;display:flex}.avatar-sm{width:32px;height:32px;font-size:12px}.user-cell-name{color:var(--text);font-weight:600}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=540px){.form-grid{grid-template-columns:1fr}}.drawer-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:150;background:#141e3266;justify-content:flex-end;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.drawer{background:#fff;flex-direction:column;width:100%;max-width:540px;height:100vh;animation:.24s cubic-bezier(.16,1,.3,1) slideIn;display:flex;box-shadow:-20px 0 60px #141e3c2e}.drawer-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:12px;padding:22px 24px 18px;display:flex}.drawer-eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft);font-size:11px;font-weight:600}.drawer-title{letter-spacing:-.01em;margin:2px 0 4px;font-size:19px;font-weight:700}.drawer-count{color:var(--text-muted);font-size:13px}.drawer-body{flex:1;padding:18px 24px 28px;overflow-y:auto}.empty-state{text-align:center;padding:40px 16px}.empty-state h4{margin:14px 0 4px;font-size:15px}.empty-icon{background:var(--primary-soft);width:70px;height:70px;color:var(--primary);border-radius:50%;place-items:center;display:inline-grid}.op-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.op-item{border-radius:var(--radius);border:1px solid var(--border);background:#fff;gap:14px;padding:16px;transition:all .15s;display:flex}.op-item:hover{box-shadow:var(--shadow-sm);border-color:#c8d3e3}.op-index{background:var(--primary-soft);width:30px;height:30px;color:var(--primary);border-radius:50%;flex-shrink:0;place-items:center;font-size:13px;font-weight:700;display:grid}.op-main{flex:1;min-width:0}.op-row-top{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:10px;display:flex}.op-patient{color:var(--text);letter-spacing:-.005em;font-size:15px;font-weight:700}.op-time{color:var(--primary);background:var(--primary-soft);border-radius:999px;flex-shrink:0;padding:3px 10px;font-size:13px;font-weight:600}.op-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px 16px;margin-bottom:10px;display:grid}.op-field{flex-direction:column;gap:2px;min-width:0;display:flex}.op-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);font-size:11px;font-weight:600}.op-value{color:var(--text);word-break:break-word;font-size:13.5px}.op-actions{border-top:1px dashed var(--border);justify-content:flex-end;gap:6px;margin-top:4px;padding-top:6px;display:flex}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@media (width<=600px){.drawer{max-width:100%}.drawer-head{padding:18px 18px 14px}.drawer-body{padding:16px 18px 24px}}.calendar-card{padding:18px 18px 6px}.fc{--fc-border-color:var(--border);--fc-today-bg-color:#4f7cf20f;--fc-button-bg-color:#fff;--fc-button-border-color:var(--border-strong);--fc-button-text-color:var(--text);--fc-button-hover-bg-color:#f4f7fc;--fc-button-hover-border-color:#b8c5d5;--fc-button-active-bg-color:var(--primary);--fc-button-active-border-color:var(--primary);--fc-event-bg-color:transparent;--fc-event-border-color:transparent;--fc-event-text-color:inherit;--fc-bg-event-color:transparent;--fc-bg-event-opacity:0;font-family:var(--font)}.fc .fc-toolbar.fc-header-toolbar{flex-wrap:wrap;gap:10px;margin-bottom:18px}.fc .fc-toolbar-title{letter-spacing:-.01em;color:var(--text);font-size:20px;font-weight:700}.fc .fc-button{text-transform:capitalize;box-shadow:none;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;transition:all .15s}.fc .fc-button:focus,.fc .fc-button:hover{box-shadow:none}.fc .fc-button-primary:not(:disabled).fc-button-active{background:var(--primary);border-color:var(--primary);color:#fff}.fc .fc-button-primary:disabled{opacity:.5}.fc .fc-daygrid-day{cursor:pointer;transition:background-color .12s}.fc .fc-daygrid-day:hover{background:#4f7cf20a}.fc .fc-day-other{background:#fbfcfd}.fc .fc-day-other .fc-daygrid-day-number{color:#c9d3df}.fc .fc-col-header-cell{border-color:var(--border);background:#f8fafd}.fc .fc-col-header-cell-cushion{text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);padding:10px 6px;font-size:11px;font-weight:700}.fc .fc-daygrid-day-frame{min-height:120px;padding:4px 4px 6px}.fc .fc-daygrid-day-top{flex-direction:row;justify-content:flex-end;padding:2px 4px 0}.fc .fc-daygrid-day-number{color:var(--text);border-radius:999px;padding:2px 6px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s}.fc .fc-day-today .fc-daygrid-day-number{color:#fff;background:var(--primary);justify-content:center;align-items:center;min-width:24px;height:24px;padding:0 8px;font-size:12px;font-weight:700;display:inline-flex;box-shadow:0 4px 10px #4f7cf252}.fc .fc-bg-event,.fc .fc-non-business{opacity:0!important;background:0 0!important}.fc .fc-daygrid-event-harness{margin-top:2px}.fc .fc-daygrid-day-events{min-height:0;margin-top:2px;padding:0 4px}.fc .fc-daygrid-event,.fc .fc-daygrid-block-event,.fc .fc-h-event{cursor:pointer;border-radius:6px;font-size:11px;overflow:hidden;box-shadow:none!important;background:0 0!important;border:none!important;margin:0!important;padding:0!important}.fc .fc-daygrid-event .fc-event-main,.fc .fc-daygrid-event .fc-event-main-frame,.fc .fc-daygrid-event .fc-event-title,.fc .fc-daygrid-event .fc-event-title-container,.fc .fc-daygrid-event .fc-event-time{color:inherit!important;background:0 0!important;margin:0!important;padding:0!important}.op-mini{background:var(--primary-soft);border-left:3px solid var(--primary);border-radius:6px;align-items:center;gap:6px;min-width:0;padding:3px 7px 3px 6px;line-height:1.25;transition:background .15s,transform .1s;display:flex;overflow:hidden}.fc .fc-daygrid-event:hover .op-mini{background:#dde7fb;transform:translate(1px)}.op-mini-time{color:var(--primary);font-variant-numeric:tabular-nums;letter-spacing:-.01em;flex-shrink:0;font-size:10.5px;font-weight:700}.op-mini-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:auto;min-width:0;font-size:11px;font-weight:500;overflow:hidden}.fc .fc-daygrid-more-link{color:var(--primary);cursor:pointer;background:#4f7cf214;border-radius:6px;margin:2px 4px 0;padding:2px 8px;font-size:11px;font-weight:600;text-decoration:none;transition:background .15s;display:inline-block}.fc .fc-daygrid-more-link:hover{background:var(--primary-soft);text-decoration:none}.form-grid-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=920px){.fc .fc-daygrid-day-frame{min-height:100px}.op-mini{border-left-width:2px;gap:4px;padding:2px 5px}.op-mini-time{font-size:10px}.op-mini-name{font-size:10.5px}}@media (width<=640px){.calendar-card{padding:12px 10px 4px}.fc .fc-daygrid-day-frame{min-height:78px;padding:2px 2px 4px}.fc .fc-daygrid-day-top{padding:2px 4px 0}.fc .fc-daygrid-day-events{padding:0 2px}.fc .fc-daygrid-day-number{padding:1px 4px;font-size:12px}.op-mini{gap:3px;padding:2px 4px}.op-mini-time{display:none}.op-mini-name{font-size:10px}.fc .fc-daygrid-more-link{margin:1px 2px 0;padding:1px 5px;font-size:10px}.form-grid-2{grid-template-columns:1fr}}@media (width<=420px){.fc .fc-toolbar-title{font-size:16px}.fc .fc-button{padding:6px 10px;font-size:12px}.fc .fc-daygrid-day-frame{min-height:64px}}
