@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary:#c8627a;--primary-hover:#b55069;--primary-light:#f5e6ea;--primary-lighter:#fdf3f5;--secondary:#7c5cbf;--accent:#e8a0b4;--bg:#f7f7f8;--surface:#fff;--surface-2:#f3f4f6;--border:#e8e8ec;--border-light:#f0f0f3;--text-primary:#1a1a2e;--text-secondary:#6b7280;--text-muted:#9ca3af;--success:#10b981;--success-light:#d1fae5;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#ef4444;--danger-light:#fee2e2;--sidebar-width:240px;--header-height:64px;--radius:12px;--radius-sm:8px;--radius-lg:18px;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow:0 4px 12px #00000014;--shadow-lg:0 8px 32px #0000001f;--transition:.25s cubic-bezier(.16, 1, .3, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px}.app-layout{height:100vh;display:flex;position:relative;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);z-index:1100;transition:transform var(--transition);flex-direction:column;flex-shrink:0;display:flex;position:relative}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.sidebar-logo{flex:1}.sidebar-logo img{width:100%;max-width:150px;height:auto;display:block}.sidebar-close{cursor:pointer;color:var(--text-primary);border-radius:var(--radius-sm);transition:background var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;display:flex}.sidebar-close:hover{background:var(--bg)}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex;overflow-y:auto}.nav-item{color:#2d3748;cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:12px 16px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.nav-item-content{align-items:center;gap:12px;display:flex}.nav-item:hover{background:var(--bg);color:var(--text-primary)}.nav-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}.nav-item .nav-icon{flex-shrink:0;width:20px;height:20px}.nav-arrow{opacity:0;transition:all var(--transition);transform:translate(-5px)}.nav-item.active .nav-arrow{opacity:1;transform:translate(0)}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:12px;padding:16px;display:flex}.avatar{background:var(--primary-light);width:38px;height:38px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.sidebar-footer .user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;overflow:hidden}.sidebar-footer .user-role{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1050;background:#0006;animation:.15s fadeIn;position:fixed;inset:0}.main-content{flex-direction:column;flex:1;width:100%;min-width:0;display:flex;overflow:hidden}.header{height:var(--header-height);background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;padding:0 24px;display:flex}.header-left{flex:1;align-items:center;gap:12px;display:flex}.menu-toggle{cursor:pointer;border-radius:var(--radius-sm);width:40px;height:40px;color:var(--text-primary);transition:background var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:none}.menu-toggle:hover{background:var(--bg)}.search-bar{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);flex:1;align-items:center;gap:8px;max-width:360px;padding:6px 14px;display:flex}.search-bar input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-size:13.5px}.search-bar input::placeholder{color:var(--text-muted)}.header-right{align-items:center;gap:12px;margin-left:auto;display:flex}.header-time{color:var(--text-secondary);white-space:nowrap;font-size:13px}.icon-btn{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;width:38px;height:38px;color:var(--text-secondary);transition:all var(--transition);background:0 0;justify-content:center;align-items:center;display:flex}.icon-btn:hover{background:var(--bg);color:var(--text-primary)}.page-content{flex:1;padding:28px;overflow-y:auto}.page-title{color:var(--text-primary);font-size:26px;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:13px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:24px;display:flex}.page-header-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13.5px;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 12px #c8627a4d}.btn-outline{color:var(--text-primary);border:1px solid var(--border);background:#fff}.btn-outline:hover{background:var(--bg);border-color:var(--primary);color:var(--primary)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:12.5px}.btn-lg{padding:11px 22px;font-size:15px}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-primary);font-size:15px;font-weight:600}.card-subtitle{color:var(--text-muted);margin-top:2px;font-size:12px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:16px;padding:20px;display:flex}.stat-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-icon.pink{background:var(--primary-light);color:var(--primary)}.stat-icon.purple{color:var(--secondary);background:#ede9ff}.stat-icon.green{background:var(--success-light);color:var(--success)}.stat-icon.yellow{background:var(--warning-light);color:var(--warning)}.stat-value{color:var(--text-primary);font-size:24px;font-weight:700}.stat-label{color:var(--text-secondary);margin-top:2px;font-size:12.5px}.table-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}table{border-collapse:collapse;width:100%}thead{background:var(--bg)}th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:12px 16px;font-size:12px;font-weight:600}td{border-bottom:1px solid var(--border-light);color:var(--text-primary);vertical-align:middle;padding:14px 16px;font-size:13.5px}tr:last-child td{border-bottom:none}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--bg)}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-success{background:var(--success-light);color:#065f46}.badge-warning{background:var(--warning-light);color:#92400e}.badge-danger{background:var(--danger-light);color:#991b1b}.badge-info{color:#5b21b6;background:#ede9ff}.badge-muted{background:var(--surface-2);color:var(--text-secondary)}.badge-primary{background:var(--primary-light);color:var(--primary)}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-primary);font-size:13px;font-weight:600}.form-input,.form-select,.form-textarea{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);background:var(--surface);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:9px 12px;font-family:inherit;font-size:13.5px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #c8627a1f}.form-textarea{resize:vertical;min-height:100px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.form-hint{color:var(--text-muted);font-size:11.5px}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:640px;max-height:90vh;animation:.2s slideUp;overflow-y:auto}.modal-lg{max-width:820px}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-title{font-size:18px;font-weight:700}.modal-close{border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;color:var(--text-muted);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg);color:var(--text-primary)}.modal-body{flex-direction:column;gap:16px;padding:20px 24px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:20px;display:flex}.tab-btn{cursor:pointer;color:var(--text-muted);transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 18px;font-size:13.5px;font-weight:500}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.cal-header{text-align:center;color:var(--text-muted);text-transform:uppercase;padding:6px 0;font-size:12px;font-weight:600}.cal-day{border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;min-height:80px;transition:all var(--transition);padding:6px}.cal-day:hover{background:var(--primary-lighter);border-color:var(--accent)}.cal-day.other-month{background:var(--bg);opacity:.5}.cal-day.today{border-color:var(--primary);background:var(--primary-lighter)}.cal-day.has-sessions{border-left:3px solid var(--primary)}.cal-day-num{color:var(--text-secondary);margin-bottom:4px;font-size:12px;font-weight:600}.cal-day.today .cal-day-num{color:var(--primary)}.cal-event{background:var(--primary-light);color:var(--primary);white-space:nowrap;text-overflow:ellipsis;border-radius:4px;margin-bottom:2px;padding:2px 5px;font-size:10.5px;font-weight:500;overflow:hidden}.cal-nav{align-items:center;gap:12px;margin-bottom:16px;display:flex}.cal-nav h3{text-align:center;flex:1;font-size:17px;font-weight:700}.empty-state{text-align:center;color:var(--text-muted);padding:48px 20px}.patient-row{cursor:pointer}.patient-avatar{background:var(--primary-light);width:34px;height:34px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.patient-info{align-items:center;gap:10px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{height:100%;color:var(--text-muted);justify-content:center;align-items:center;gap:12px;display:flex}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.w-full{width:100%}.font-bold{font-weight:700}.font-medium{font-weight:500}.text-sm{font-size:12.5px}.text-xs{font-size:11.5px}.section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:700}.info-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.info-item .info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:11.5px;font-weight:600}.info-item .info-value{color:var(--text-primary);font-size:14px;font-weight:500}.alert{border-radius:var(--radius-sm);align-items:flex-start;gap:12px;margin-bottom:16px;padding:14px 16px;font-size:13px;display:flex}.alert-info{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.alert-warning{background:var(--warning-light);color:#92400e;border:1px solid #fde68a}.mobile-only{display:none!important}.mobile-cards{display:none}@media (width<=1024px){:root{--sidebar-width:280px}.menu-toggle,.mobile-only{display:flex!important}.sidebar{height:100%;box-shadow:var(--shadow-lg);background:#fff;position:fixed;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.header{padding:0 16px}.page-content{padding:16px}}@media (width<=768px){:root{--header-height:60px}.hidden-mobile{display:none!important}.form-row,.form-row-3{grid-template-columns:1fr;gap:16px}.modal{border-radius:20px 20px 0 0;max-height:95vh;margin:0;position:fixed;bottom:0}.page-header{flex-direction:column;align-items:stretch;gap:16px}.page-header-actions{grid-template-columns:1fr;gap:10px;width:100%;display:grid}.stats-grid{grid-template-columns:1fr;gap:16px}.table-container table{display:none}.mobile-cards{gap:16px;padding-bottom:24px;display:grid}.card-mobile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px}.cal-day{min-height:50px;padding:4px}}.empty-state{text-align:center;color:var(--text-muted);background:var(--surface);border-radius:var(--radius);border:1px dashed var(--border);padding:60px 24px}.empty-state p{margin-top:12px;font-size:14px}.empty-state .empty-icon{color:var(--text-muted);opacity:.3}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
