/* ====== Variables couleur ====== */
:root {
    --sas-navy: #1d2d5c;
    --sas-navy-dark: #16234a;
    --sas-peach: #fbe3d4;
    --sas-bg-light: #f4f6fb;
    --sas-text: #1d2d5c;
    --sas-text-muted: #6b7280;
    --sas-border: #e2e6f0;
    --sas-success: #1f9d55;
    --sas-error: #c0392b;
    --sas-radius: 16px;
}

/* ====== Header minimal (remplace le header du thème sur les pages auth/dashboard) ====== */
.sas-minimal-header {
    position: relative !important;
    display: block !important;
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    padding: 24px 90px 0 20px;
    box-sizing: border-box;
    min-height: 56px;
}

.sas-minimal-logo {
    display: inline-flex !important;
    align-items: center;
    text-decoration: none;
}

.sas-minimal-logo img {
    max-height: 48px;
    width: auto;
    display: block;
}

.sas-minimal-logo span {
    font-size: 20px;
    font-weight: 800;
    color: var(--sas-navy);
}

.sas-minimal-header .sas-btn-logout {
    position: absolute !important;
    top: 24px;
    right: 20px;
    margin: 0 !important;
    width: auto !important;
}

/* ====== Pages d'auth (connexion / changer mot de passe) ====== */
.sas-auth-page {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
    padding: 40px 20px;
    background: var(--sas-bg-light);
}

.sas-auth-card {
    background: #fff;
    border-radius: var(--sas-radius);
    padding: 48px 40px;
    max-width: 440px;
    width: 100%;
    box-shadow: 0 10px 40px rgba(29, 45, 92, 0.08);
}

.sas-auth-card h1 {
    color: var(--sas-navy);
    font-size: 28px;
    font-weight: 800;
    margin: 0 0 8px;
}

.sas-subtitle {
    color: var(--sas-text-muted);
    margin: 0 0 28px;
    font-size: 15px;
}

/* ====== Formulaires ====== */
.sas-form .sas-field {
    margin-bottom: 18px;
}

.sas-form label {
    display: block;
    font-weight: 600;
    color: var(--sas-navy);
    margin-bottom: 6px;
    font-size: 14px;
}

.sas-form input {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--sas-border);
    border-radius: 10px;
    font-size: 15px;
    box-sizing: border-box;
    transition: border-color 0.2s;
}

.sas-form input:focus {
    outline: none;
    border-color: var(--sas-navy);
}

.sas-form input:disabled {
    background: var(--sas-bg-light);
    color: var(--sas-text-muted);
}

.sas-btn-primary {
    width: 100%;
    padding: 14px 24px;
    background: var(--sas-navy);
    color: #fff;
    border: none;
    border-radius: 999px;
    font-weight: 700;
    font-size: 15px;
    cursor: pointer;
    margin-top: 8px;
    transition: background 0.2s;
    display: inline-block;
    text-align: center;
    text-decoration: none;
}

.sas-btn-primary:hover {
    background: var(--sas-navy-dark);
    color: #fff;
}

.sas-link {
    display: inline-block;
    margin-top: 18px;
    color: var(--sas-navy);
    font-size: 14px;
    text-decoration: none;
}

.sas-link:hover {
    text-decoration: underline;
}

/* ====== Alertes ====== */
.sas-alert {
    padding: 12px 16px;
    border-radius: 10px;
    font-size: 14px;
    margin-bottom: 20px;
}

.sas-alert-error {
    background: #fdecea;
    color: var(--sas-error);
    border: 1px solid #f5c6cb;
}

.sas-alert-success {
    background: #e9f8ee;
    color: var(--sas-success);
    border: 1px solid #c3e6cb;
}

/* ====== Dashboards (patient / médecin) ====== */
.sas-dashboard {
    max-width: 1000px;
    margin: 40px auto;
    padding: 0 20px 60px;
}

.sas-dashboard-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 28px;
    flex-wrap: wrap;
    gap: 12px;
}

.sas-dashboard-header h1 {
    color: var(--sas-navy);
    font-size: 30px;
    font-weight: 800;
    margin: 0;
}

.sas-header-subtitle {
    color: var(--sas-text-muted);
    font-size: 14px;
    margin: 4px 0 0;
}

/* ====== Cartes statistiques ====== */
.sas-stats-row {
    display: flex;
    gap: 16px;
    margin-bottom: 28px;
    flex-wrap: wrap;
}

.sas-stat-card {
    background: #fff;
    border: 1px solid var(--sas-border);
    border-radius: var(--sas-radius);
    padding: 20px 24px;
    flex: 1;
    min-width: 160px;
    box-shadow: 0 2px 12px rgba(29, 45, 92, 0.04);
}

.sas-stat-number {
    display: block;
    font-size: 32px;
    font-weight: 800;
    color: var(--sas-navy);
    line-height: 1.2;
}

.sas-stat-label {
    display: block;
    font-size: 13px;
    color: var(--sas-text-muted);
    margin-top: 4px;
}

/* ====== Badges (statut, échéance) ====== */
.sas-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.sas-badge-approved {
    background: #e9f8ee;
    color: var(--sas-success);
}

.sas-badge-pending {
    background: #fff8e6;
    color: #b8860b;
}

.sas-badge-canceled {
    background: #fdecea;
    color: var(--sas-error);
}

.sas-badge-upcoming {
    background: #e8edfb;
    color: var(--sas-navy);
}

.sas-badge-past {
    background: #f1f1f1;
    color: var(--sas-text-muted);
}

.sas-btn-inline {
    margin-top: 20px;
    display: inline-block;
    width: auto;
    padding: 14px 28px;
}

.sas-btn-logout {
    padding: 10px 22px;
    border-radius: 999px;
    background: var(--sas-bg-light);
    color: var(--sas-navy);
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
    border: 1px solid var(--sas-border);
    transition: background 0.2s;
}

.sas-btn-logout:hover {
    background: var(--sas-peach);
}

/* ====== Onglets ====== */
.sas-tabs {
    display: flex;
    gap: 10px;
    margin-bottom: 28px;
    flex-wrap: wrap;
    border-bottom: 1px solid var(--sas-border);
    padding-bottom: 4px;
}

.sas-tab {
    padding: 10px 20px;
    border-radius: 999px;
    text-decoration: none;
    color: var(--sas-text-muted);
    font-weight: 600;
    font-size: 14px;
    transition: all 0.2s;
}

.sas-tab:hover {
    background: var(--sas-bg-light);
}

.sas-tab.active {
    background: var(--sas-navy);
    color: #fff;
}

.sas-tab-content {
    display: none;
}

.sas-tab-content.active {
    display: block;
    animation: sas-fade-in 0.2s ease;
}

@keyframes sas-fade-in {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: translateY(0); }
}

.sas-tab-content h2 {
    color: var(--sas-navy);
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 18px;
}

/* ====== Tables ====== */
.sas-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border-radius: var(--sas-radius);
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(29, 45, 92, 0.05);
}

.sas-table th {
    background: var(--sas-bg-light);
    color: var(--sas-navy);
    text-align: left;
    padding: 14px 16px;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.sas-table td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--sas-border);
    font-size: 14px;
    color: var(--sas-text);
}

.sas-table tr:last-child td {
    border-bottom: none;
}

/* ====== Placeholder (zones informatives) ====== */
.sas-placeholder-notice {
    background: var(--sas-peach);
    border-radius: var(--sas-radius);
    padding: 20px 24px;
    margin-bottom: 20px;
    color: var(--sas-navy);
    font-size: 14px;
}

.sas-placeholder-notice p {
    margin: 0;
}

/* ====== Liste documents ====== */
.sas-doc-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sas-doc-list li {
    padding: 14px 18px;
    background: #fff;
    border: 1px solid var(--sas-border);
    border-radius: 10px;
    margin-bottom: 10px;
}

.sas-doc-list a {
    color: var(--sas-navy);
    font-weight: 600;
    text-decoration: none;
}

.sas-doc-list a:hover {
    text-decoration: underline;
}

/* ====== Responsive ====== */
@media (max-width: 600px) {
    .sas-auth-card {
        padding: 32px 24px;
    }
    .sas-dashboard-header {
        flex-direction: column;
        align-items: flex-start;
    }
    .sas-table {
        display: block;
        overflow-x: auto;
    }
}
