/* ============================================================
   ConsultorioMD — Page-Specific Styles
   ============================================================ */

/* ── Login Page ── */
.login-page { min-height: 100vh; display: flex; }
.login-left {
    flex: 1; background: var(--primary-gradient); display: flex; flex-direction: column;
    align-items: center; justify-content: center; padding: var(--space-2xl); color: #fff;
    position: relative; overflow: hidden;
}
.login-left::before {
    content: ''; position: absolute; inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.login-left h1 { font-size: 2.5rem; font-weight: 800; margin-bottom: var(--space-md); position: relative; }
.login-left p { font-size: 1.125rem; opacity: 0.9; max-width: 400px; text-align: center; position: relative; }
.login-left .login-features { list-style: none; margin-top: var(--space-xl); position: relative; }
.login-left .login-features li { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; font-size: 0.95rem; opacity: 0.9; }
.login-left .login-features li svg { width: 20px; height: 20px; flex-shrink: 0; }

.login-right {
    width: 480px; display: flex; flex-direction: column;
    align-items: center; justify-content: center; padding: var(--space-2xl);
    background: var(--bg-primary);
}
.login-form { width: 100%; max-width: 360px; }
.login-form h2 { font-size: 1.5rem; margin-bottom: 6px; }
.login-form p { color: var(--text-secondary); margin-bottom: var(--space-xl); }
.login-form .form-group { margin-bottom: var(--space-lg); }
.login-form .btn { width: 100%; padding: 12px; font-size: 1rem; }
.login-logo { display: flex; align-items: center; gap: 10px; margin-bottom: var(--space-xl); }
.login-logo-icon { width: 44px; height: 44px; border-radius: var(--radius-md); background: var(--primary-gradient); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 1.1rem; }
.login-logo-text { font-size: 1.3rem; font-weight: 700; color: var(--text-primary); }
.login-logo-text span { color: var(--primary); }
.login-footer { margin-top: var(--space-xl); text-align: center; font-size: 0.8125rem; color: var(--text-tertiary); }

@media (max-width: 900px) {
    .login-left { display: none; }
    .login-right { width: 100%; }
}

/* ── Dashboard ── */
.dashboard-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); margin-top: var(--space-lg); }
.dashboard-grid .full-width { grid-column: 1 / -1; }
@media (max-width: 1024px) { .dashboard-grid { grid-template-columns: 1fr; } }

.chart-container { position: relative; height: 300px; }
.chart-container canvas { width: 100% !important; height: 100% !important; }

.activity-list { list-style: none; }
.activity-item { display: flex; align-items: flex-start; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--border); }
.activity-item:last-child { border-bottom: none; }
.activity-dot { width: 8px; height: 8px; border-radius: var(--radius-full); background: var(--primary); margin-top: 6px; flex-shrink: 0; }
.activity-content { flex: 1; }
.activity-content p { font-size: 0.875rem; color: var(--text-primary); margin-bottom: 2px; }
.activity-content small { font-size: 0.75rem; color: var(--text-tertiary); }

/* ── Patient Detail ── */
.patient-header { display: flex; align-items: center; gap: var(--space-lg); margin-bottom: var(--space-lg); }
.patient-header .avatar-xl { width: 100px; height: 100px; font-size: 2rem; }
.patient-info h2 { margin-bottom: 4px; }
.patient-info p { margin-bottom: 2px; }
.patient-meta { display: flex; flex-wrap: wrap; gap: var(--space-md); margin-top: var(--space-sm); }
.patient-meta-item { display: flex; align-items: center; gap: 6px; font-size: 0.8125rem; color: var(--text-secondary); }
.patient-meta-item svg { width: 16px; height: 16px; }

.tab-content { display: none; padding-top: var(--space-lg); animation: fadeIn 0.3s ease; }
.tab-content.active { display: block; }

/* ── Calendar ── */
.fc { font-family: var(--font-family) !important; }
.fc .fc-toolbar-title { font-size: 1.125rem !important; font-weight: 700 !important; }
.fc .fc-button { background: var(--bg-tertiary) !important; border: 1px solid var(--border) !important; color: var(--text-primary) !important; font-family: var(--font-family) !important; font-size: 0.8125rem !important; border-radius: var(--radius-sm) !important; padding: 6px 12px !important; }
.fc .fc-button:hover { background: var(--bg-hover) !important; }
.fc .fc-button-active { background: var(--primary) !important; color: #fff !important; border-color: var(--primary) !important; }
.fc .fc-daygrid-day { border-color: var(--border) !important; }
.fc .fc-event { border-radius: var(--radius-sm) !important; padding: 2px 6px !important; font-size: 0.75rem !important; border: none !important; }
.fc .fc-col-header-cell { background: var(--bg-secondary) !important; border-color: var(--border) !important; }
.fc .fc-scrollgrid { border-color: var(--border) !important; }

/* ── Vital Signs Grid ── */
.vitals-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--space-md); }
.vital-card { background: var(--bg-secondary); border: 1px solid var(--border); border-radius: var(--radius-md); padding: var(--space-md); text-align: center; }
.vital-card .vital-label { font-size: 0.75rem; color: var(--text-tertiary); margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.05em; }
.vital-card .vital-value { font-size: 1.25rem; font-weight: 700; color: var(--text-primary); }
.vital-card .vital-unit { font-size: 0.75rem; color: var(--text-secondary); }

/* ── Print Styles ── */
@media print {
    .sidebar, .navbar, .sidebar-overlay, .toast-container, .btn, .table-toolbar { display: none !important; }
    .main-wrapper { margin: 0 !important; }
    .main-content { padding: 0 !important; }
    .card { box-shadow: none !important; border: 1px solid #ddd !important; }
}
