/* --- Paleta de Cores e Variáveis "Clínica Clean" --- */
:root {
    --primary-purple: #6A0DAD;
    --primary-light: #F3E8FF;
    --background-main: #F8F9FA;
    --surface-card: #FFFFFF;
    --text-primary: #344054;
    --text-secondary: #667085;
    --border-color: #EAECF0;
    --danger-color: #D92D20;
    --font-family-sans: 'Inter', sans-serif, system-ui;
    --shadow-md: 0 4px 8px -2px rgb(16 24 40 / 0.1), 0 2px 4px -2px rgb(16 24 40 / 0.06);
}

/* --- Reset Básico e Estilo do Body --- */
* { box-sizing: border-box; margin: 0; padding: 0; }
html { font-family: var(--font-family-sans); }
body { background-color: var(--background-main); color: var(--text-primary); }

/* --- Layout Principal --- */
#app-container { display: flex; min-height: auto; }
.main-content { flex: 1; padding: 2.5rem; overflow-y: auto; }
#page-title { font-size: 2rem; font-weight: 600; color: var(--text-primary); margin-bottom: 2rem; }

/* --- Sidebar (Menu Lateral) --- */
.sidebar { width: 280px; background-color: var(--surface-card); border-right: 1px solid var(--border-color); display: flex; flex-direction: column; transition: width 0.3s ease, transform 0.3s ease; }
.sidebar-header { display: flex; align-items: center; gap: 0.75rem; padding: 1.5rem; border-bottom: 1px solid var(--border-color); }
.logo-icon { color: var(--primary-purple); font-size: 28px; }
.sidebar-header h2 { font-size: 1.25rem; color: var(--text-primary); }
.sidebar-nav { flex: 1; padding: 1rem; }
.nav-item { display: flex; align-items: center; gap: 0.75rem; padding: 0.85rem 1rem; margin-bottom: 0.25rem; text-decoration: none; color: var(--text-secondary); font-weight: 500; border-radius: 8px; transition: all 0.2s; white-space: nowrap; }
.nav-item i.fa-fw { font-size: 1.1rem; }
.nav-item:hover { background-color: var(--primary-light); color: var(--primary-purple); }
.nav-item.active { background-color: var(--primary-purple); color: white; font-weight: 600; box-shadow: var(--shadow-md); }
.nav-item.active i.fa-fw { color: white; }
.sidebar-footer { padding: 1.5rem; text-align: center; color: var(--text-secondary); font-size: 0.875rem; border-top: 1px solid var(--border-color); }

/* --- Componentes CRUD e Botões --- */
.crud-container { background-color: var(--surface-card); border-radius: 12px; border: 1px solid var(--border-color); box-shadow: var(--shadow-md); }
.crud-header { padding: 1.25rem 1.5rem; border-bottom: 1px solid var(--border-color); display: flex; justify-content: space-between; align-items: center; }
.crud-header h3 { font-size: 1.125rem; }
.crud-body { padding: 1.5rem; }
.crud-table { width: 100%; border-collapse: collapse; }
.crud-table th, .crud-table td { padding: 1rem 1.5rem; text-align: left; border-bottom: 1px solid var(--border-color); }
.crud-table th { font-size: 0.75rem; color: var(--text-secondary); text-transform: uppercase; }
.crud-table td.actions { text-align: right; white-space: nowrap; }
.btn { border: 1px solid var(--border-color); border-radius: 8px; padding: 0.6rem 1.25rem; font-weight: 600; cursor: pointer; transition: all 0.2s ease-out; }
.btn:active { transform: scale(0.98); }
.btn-primary { background-color: var(--primary-purple); color: white; border-color: var(--primary-purple); }
.btn-primary:hover { background-color: #581C87; border-color: #581C87; }
.btn-secondary { background-color: var(--surface-card); color: var(--text-secondary); }
.btn-edit, .btn-delete, .btn-delete-horario { background: none; border: none; padding: 0.5rem; color: var(--text-secondary); }
.btn-delete:hover, .btn-delete-horario:hover { color: var(--danger-color); }

/* --- Formulários e Modais --- */
.form-group { margin-bottom: 1.25rem; }
label { display: block; font-weight: 500; margin-bottom: 0.5rem; font-size: 0.875rem; color: var(--text-primary); }
input, select, textarea { width: 100%; padding: 0.75rem; border: 1px solid var(--border-color); border-radius: 8px; font-size: 1rem; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--primary-purple); box-shadow: 0 0 0 3px rgba(106, 90, 205, 0.2); }
.modal-overlay { position: fixed; inset: 0; z-index: 1000; display: flex; justify-content: center; align-items: center; background-color: rgba(17, 24, 39, 0.4); backdrop-filter: blur(4px); }
.modal-container { background: var(--surface-card); padding: 2.5rem; border-radius: 16px; width: 90%; max-width: 600px; box-shadow: var(--shadow-lg); }
.modal-actions { display: flex; justify-content: flex-end; gap: 1rem; margin-top: 2rem; }
.form-grid { display: grid; gap: 1.5rem; grid-template-columns: 1fr 1fr; }
.form-inline { display: flex; gap: 1rem; align-items: flex-end; flex-wrap: wrap; }

/* --- Tabela de Escala --- */
#escala-view { overflow-x: auto; /* Garante rolagem horizontal em telas pequenas */ }
#escala-view table { width: 100%; min-width: 900px; /* Largura mínima para evitar quebra de colunas */ border-collapse: separate; border-spacing: 0; border: 1px solid var(--border-color); border-radius: 12px; }
#escala-view th { background-color: #F9FAFB; color: var(--text-secondary); text-transform: uppercase; font-size: 0.875rem; text-align: center; padding: 1rem 0.5rem; }
#escala-view td { vertical-align: middle; text-align: center; padding: 0.75rem; border-top: 1px solid var(--border-color); }
.especialidade-cell { font-weight: 600; font-size: 1.1rem; color: var(--primary-purple); background-color: var(--primary-light); text-align: left !important; }
.profissional-cell { padding-left: 2rem !important; text-align: left !important; font-weight: 500; }
.horario-cell div { padding: 0.75rem; margin: 0 auto 0.5rem; border-radius: 6px; position: relative; line-height: 1.5; font-size: 0.9rem; max-width: 200px; }
.horario-cell div:not(:empty) { background-color: #F9FAFB; border: 1px solid #F3F4F6; }
.horario-cell div:hover { background-color: #EFF6FF; }
.horario-cell span { color: var(--text-secondary); font-size: 0.8rem; display: block; }
.btn-delete-horario { position: absolute; right: 4px; top: 4px; color: #D1D5DB; background: none; border: none; cursor: pointer; opacity: 0; }
.horario-cell div:hover .btn-delete-horario { opacity: 1; }
.hidden { display: none; }


#app-footer {
    width: 100%;
    padding: 1rem;
    text-align: center;
    background-color: var(--surface-card);
    border-top: 1px solid var(--border-color);
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* --- RESPONSIVIDADE (MEDIA QUERIES) --- */
@media (max-width: 768px) {
    #app-container { flex-direction: column; }
    .sidebar { width: 100%; height: auto; flex-direction: row; box-shadow: var(--shadow-md); }
    .sidebar-header { display: none; }
    .sidebar-nav { flex: 1; display: flex; flex-direction: row; justify-content: space-around; padding: 0.5rem; overflow-x: auto; }
    .nav-item { flex-shrink: 0; }
    .nav-item span { display: none; } /* Esconde o texto dos ícones em telas pequenas */
    .main-content { padding: 1.5rem; }
    #page-title { font-size: 1.75rem; }
    .form-grid { grid-template-columns: 1fr; }
    .form-inline { flex-direction: column; align-items: stretch; }
    .form-inline .form-group, .form-inline .form-actions { width: 100%; }
    .escala-filtros .form-inline { flex-direction: row; align-items: flex-end; } /* Mantém filtros em linha se possível */
}

