*{box-sizing:border-box}body{margin:0}#root{min-height:100vh}*,:before,:after{box-sizing:border-box}.app{color:#0f172a;text-align:left;background:#f1f5f9;min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,Roboto,sans-serif;font-size:13px}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:.625rem 1.5rem;display:flex;box-shadow:0 1px 2px #0f172a0a}.topbar-left{align-items:center;gap:.875rem;display:flex}.logo{object-fit:contain;width:auto;height:28px;display:block}.search-global{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:.5rem;min-width:220px;padding:.4rem .875rem;display:flex}.search-global input{color:#64748b;background:0 0;border:none;outline:none;width:160px;font-size:12px}.topbar-right{align-items:center;gap:.5rem;display:flex}.icon-btn{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:flex}.icon-btn:hover{background:#f1f5f9}.notif-wrap,.notif-btn{position:relative}.notif-badge{color:#fff;background:#ef4444;border:2px solid #fff;border-radius:9999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:2px;right:2px}.notif-dropdown{z-index:1000;background:#fff;border:1px solid #e2e8f0;border-radius:10px;width:320px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 24px #0f172a1f}.notif-dropdown-header{color:#0f172a;background:#faf5ff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:13px;font-weight:600;display:flex}.notif-count{color:#7c3aed;font-size:11px;font-weight:600}.notif-list{margin:0;padding:0;list-style:none}.notif-item{cursor:default;border-bottom:1px solid #f1f5f9;padding:.875rem 1rem;transition:background .1s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:#f8fafc}.notif-message{color:#334155;margin:0;font-size:12px;line-height:1.45}.notif-time{color:#94a3b8;margin-top:.35rem;font-size:10px;display:block}.avatar{color:#475569;background:linear-gradient(135deg,#e2e8f0,#cbd5e1);border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:600;display:flex}.page-title-bar{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 1.5rem}.page-title-bar h2{color:#0f172a;margin:0;font-size:20px;font-weight:700}.stats-grid{background:#fff;border-bottom:1px solid #e2e8f0;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:.625rem;padding:.875rem 1.25rem;display:grid}.stat-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;align-items:flex-start;gap:.625rem;padding:.75rem .875rem;display:flex}.stat-icon{flex-shrink:0;margin-top:2px;font-size:20px;line-height:1}.stat-content{flex-direction:column;gap:.25rem;min-width:0;display:flex}.stat-value{color:#0f172a;font-size:22px;font-weight:700;line-height:1;display:block}.stat-label{color:#64748b;font-size:11px;font-weight:500;line-height:1.35;display:block}.filter-bar{background:#fff;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.5rem 1.25rem;display:flex}.filter-label{color:#64748b;text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.filter-select{color:#334155;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;min-width:150px;padding:.4rem .75rem;font-size:12px}.filter-select:focus{border-color:#7c3aed;outline:none;box-shadow:0 0 0 2px #7c3aed26}.toolbar{background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:.5rem 1.25rem;display:flex}.toolbar-left,.toolbar-right{align-items:center;gap:.5rem;display:flex}.nav-arrow{cursor:pointer;color:#475569;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;display:flex}.nav-arrow:hover{background:#f8fafc}.month-title{color:#0f172a;text-align:center;min-width:140px;font-size:15px;font-weight:600}.btn-create{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:8px;padding:.5rem 1rem;font-size:13px;font-weight:600;box-shadow:0 1px 3px #7c3aed4d}.btn-create:hover{filter:brightness(1.05)}.view-select,.btn-today{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.45rem .75rem;font-size:12px}.btn-today{font-weight:500}.btn-today:hover{background:#f8fafc}.page-body{height:calc(100vh - 120px);display:flex}.page-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.timeline-wrap{background:#fff;flex:1;position:relative;overflow:auto}.timeline{flex-direction:column;min-width:max-content;display:flex;position:relative}.grid-header{z-index:20;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;position:sticky;top:0}.doctor-col-header{z-index:30;background:#fff;border-right:1px solid #e2e8f0;width:220px;min-width:220px;padding:.35rem .5rem;position:sticky;left:0}.filter-doctors{color:#64748b;border:1px solid #e2e8f0;border-radius:6px;outline:none;width:100%;padding:.3rem .5rem;font-size:11px}.filter-doctors:focus{border-color:#7c3aed;box-shadow:0 0 0 2px #7c3aed26}.day-header{text-align:center;color:#94a3b8;border-right:1px solid #f1f5f9;width:34px;min-width:34px;padding:.25rem 0;font-size:9px;font-weight:500}.day-header.weekend{background:#fefce8}.day-header .day-num{color:#475569;margin-top:1px;font-size:11px;font-weight:600;display:block}.day-header.today .day-num{color:#7c3aed}.grid-row{border-bottom:1px solid #f1f5f9;display:flex}.grid-row:hover{background:#fafafa}.doctor-cell{z-index:10;background:#fff;border-right:1px solid #e2e8f0;width:220px;min-width:220px;padding:.4rem .5rem;position:sticky;left:0}.doctor-name{color:#5b21b6;font-size:11px;font-weight:600;line-height:1.3}.doctor-specialty{color:#94a3b8;margin-top:1px;font-size:9px;line-height:1.25}.slot-cell{background:#fff;border:none;border-right:1px solid #f1f5f9;justify-content:center;align-items:center;width:34px;min-width:34px;height:36px;padding:0;display:flex}.slot-cell.weekend{background:#fefce8}.slot-cell.has-slot{cursor:pointer;transition:filter .12s,box-shadow .12s}.slot-cell.has-slot:hover{filter:brightness(.96)}.slot-cell.has-slot.selected{box-shadow:inset 0 0 0 2px #7c3aed}.slot-cell.drop-target{outline-offset:-2px;outline:2px dashed #7c3aed}.slot-cell.empty{cursor:default}.visit-count{color:#fff;text-shadow:0 1px 2px #0003;font-size:13px;font-weight:800}.today-line{z-index:5;pointer-events:none;background:#7c3aed;width:2px;position:absolute;top:0;bottom:0}.visit-tooltip{z-index:1000;pointer-events:none;background:#fff;border:1px solid #e2e8f0;border-radius:10px;max-width:300px;padding:.75rem;position:fixed;box-shadow:0 8px 24px #0f172a1f}.tooltip-title{color:#7c3aed;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem;font-size:11px;font-weight:700}.tooltip-list{margin:0;padding:0;list-style:none}.tooltip-item{border-bottom:1px solid #f1f5f9;padding:.4rem 0}.tooltip-item:last-child{border-bottom:none}.tooltip-time{color:#0f172a;font-size:12px;font-weight:600}.tooltip-meta{color:#64748b;flex-wrap:wrap;gap:.35rem;margin-top:2px;font-size:10px;display:flex}.panel{background:#fff;border-left:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;width:380px;display:flex;overflow:hidden;box-shadow:-4px 0 16px #0f172a0a}.panel-header{background:linear-gradient(#faf5ff 0%,#fff 100%);border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-start;padding:1.125rem 1.25rem;display:flex}.panel-label{text-transform:uppercase;letter-spacing:.06em;color:#7c3aed;font-size:10px;font-weight:700}.panel-header h3{color:#0f172a;margin:.3rem 0 0;font-size:15px;font-weight:700}.panel-header p{color:#64748b;margin:.2rem 0 0;font-size:12px}.close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:20px;line-height:1}.close-btn:hover{color:#475569;background:#f1f5f9}.panel-body{flex:1;padding:1rem 1.25rem;overflow-y:auto}.slot-info{color:#6d28d9;background:#f5f3ff;border:1px solid #ede9fe;border-radius:8px;margin-bottom:.875rem;padding:.65rem .875rem;font-size:12px}.slot-info strong{font-weight:700}.btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:8px;width:100%;margin-bottom:.875rem;padding:.6rem 1rem;font-size:13px;font-weight:600;box-shadow:0 1px 3px #7c3aed40}.btn-primary:hover{filter:brightness(1.05)}.btn-primary:disabled{cursor:not-allowed;filter:none;background:#c4b5fd}.empty-state{text-align:center;background:#f8fafc;border:1px dashed #e2e8f0;border-radius:10px;padding:2rem 1rem}.empty-state p{color:#475569;margin:0;font-size:13px}.empty-state small{color:#94a3b8;margin-top:.25rem;font-size:11px;display:block}.visit-list{flex-direction:column;gap:.625rem;margin:0;padding:0;list-style:none;display:flex}.visit-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:.875rem;transition:box-shadow .15s,border-color .15s}.visit-card-draggable{cursor:grab}.visit-card-draggable:active{cursor:grabbing}.visit-card-draggable:hover{border-color:#c4b5fd;box-shadow:0 2px 8px #7c3aed1a}.visit-card-header{align-items:baseline;gap:.5rem;margin-bottom:.25rem;display:flex}.visit-card-time{color:#7c3aed;background:#f5f3ff;border-radius:6px;padding:2px 8px;font-size:12px;font-weight:700}.visit-card-patient{color:#0f172a;font-size:14px;font-weight:700}.visit-card-doctor{color:#64748b;margin-bottom:.35rem;font-size:11px}.visit-card-notes{color:#64748b;background:#fff;border:1px solid #f1f5f9;border-radius:6px;margin-top:.5rem;padding:.4rem .5rem;font-size:11px}.drag-hint{color:#94a3b8;margin-top:.5rem;font-size:10px;font-style:italic}.badge{white-space:nowrap;border:1px solid;border-radius:6px;align-items:center;gap:.2rem;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-sm{padding:1px 6px;font-size:10px}.badge-row{flex-wrap:wrap;gap:.35rem;margin-top:.35rem;display:flex}.form-title-row{justify-content:space-between;align-items:center;margin-bottom:.875rem;display:flex}.form-title-row h4{margin:0;font-size:14px;font-weight:700}.btn-text{color:#64748b;cursor:pointer;background:0 0;border:none;font-size:12px;font-weight:500}.btn-text:hover{color:#0f172a}.field{margin-bottom:.75rem}.field label{color:#475569;margin-bottom:.25rem;font-size:11px;font-weight:600;display:block}.field input,.field select,.field textarea{background:#fff;border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:.5rem .7rem;font-family:inherit;font-size:13px}.field input:focus,.field select:focus,.field textarea:focus{border-color:#7c3aed;outline:none;box-shadow:0 0 0 3px #7c3aed1f}.field textarea{resize:vertical;min-height:72px}.field-error{color:#dc2626;margin-top:.25rem;font-size:11px}.time-row{gap:.5rem;display:flex}.time-row .field{flex:1}@media (width<=900px){.page-body{flex-direction:column;height:auto}.panel{width:100%;max-height:50vh}.stats-grid{grid-template-columns:repeat(2,1fr)}}
