/* ---------------------------- */
/* PALETTE SOBASO PRO */
:root {
    --orange: #FF6B00;
    --orange-dark: #e65c00;
    --blue: #0066CC;
    --blue-dark: #004a99;
    --gray-light: #f9f9f9;
    --gray-medium: #777;
    --gray-dark: #222;
    --white: #fff;
    --success: #28a745;
    --warning: #ffc107;
    --danger: #dc3545;
    --border-radius: 8px;
    --transition: 0.25s ease;
}

/* ---------------------------- */
/* GLOBAL */
body {
    margin: 0;
    padding: 0;
    font-family: "Arial", sans-serif;
    background-color: var(--gray-light);
    color: var(--gray-dark);
}

.container {
    max-width: 960px;
    margin: 30px auto 60px auto;
    background: var(--white);
    padding: 30px;
    border-radius: var(--border-radius);
    box-shadow: 0px 4px 12px rgba(0,0,0,0.08);
    border-top: 5px solid var(--orange);
}

/* TITRE */
h1 {
    color: var(--blue);
    font-size: 26px;
    margin-bottom: 20px;
    text-align: center;
    font-weight: bold;
}

/* SECTION */
.section-title {
    color: var(--orange);
    font-size: 18px;
    margin: 20px 0 10px;
    font-weight: bold;
}

/* CARTE DEMANDE */
.admin-card {
    background: var(--white);
    border-radius: var(--border-radius);
    padding: 18px 22px;
    margin-bottom: 18px;
    border-left: 6px solid var(--blue);
    box-shadow: 0px 2px 8px rgba(0,0,0,0.08);
    transition: transform .2s ease;
}
.admin-card:hover {
    transform: translateY(-1px);
    box-shadow: 0px 4px 12px rgba(0,0,0,0.12);
}

/* CONTENU CARTE */
.admin-card .client-name {
    font-size: 17px;
    font-weight: bold;
    color: var(--blue);
}
.admin-card .client-info {
    font-size: 15px;
    margin-top: 6px;
    color: var(--gray-dark);
}

/* BADGES */
.badge {
    display: inline-block;
    padding: 5px 10px;
    font-size: 12px;
    font-weight: bold;
    border-radius: 12px;
    text-transform: uppercase;
    color: #fff;
    margin-top: 8px;
}

.badge.pending    { background: var(--warning); }
.badge.validated  { background: var(--blue); }
.badge.assigned   { background: var(--blue-dark); }
.badge.en_route   { background: var(--orange); }
.badge.done       { background: var(--success); }
.badge.cancelled  { background: var(--danger); }
.badge.urgent     { background: var(--danger); float: right;}

/* FORM D’ATTRIBUTION */
.admin-card form {
    margin-top: 12px;
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.admin-card select {
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: var(--border-radius);
    flex: 1;
    font-size: 14px;
}

.admin-card button {
    padding: 10px 14px;
    border: none;
    background: var(--orange);
    color: #fff;
    font-weight: bold;
    border-radius: var(--border-radius);
    cursor: pointer;
    transition: background var(--transition);
}
.admin-card button:hover {
    background: var(--orange-dark);
}

/* RESPONSIVE */
@media (max-width: 720px) {
    .admin-card form {
        flex-direction: column;
    }
}

/* CALENDRIER / AGENDA */
.calendar {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-top: 20px;
}

.calendar-card {
    background: var(--white);
    border-radius: var(--border-radius);
    padding: 15px 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    border-left: 6px solid var(--blue);
    transition: transform 0.2s ease;
}

.calendar-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.calendar-card.urgent {
    border-left: 6px solid var(--danger);
}

.calendar-time {
    font-weight: bold;
    color: var(--gray-dark);
    margin-bottom: 5px;
}

.calendar-client {
    font-size: 14px;
    color: var(--gray-dark);
    margin-bottom: 8px;
}

.calendar-card form {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 8px;
}

.calendar-card select {
    padding: 8px;
    border-radius: var(--border-radius);
    border: 1px solid #ccc;
    flex: 1;
}

.calendar-card button {
    padding: 8px 12px;
    background: var(--orange);
    color: #fff;
    font-weight: bold;
    border-radius: var(--border-radius);
    border: none;
    cursor: pointer;
}

.calendar-card button:hover {
    background: var(--orange-dark);
}

.calendar-card label {
    padding: 8px 8px;
}

.time {
    padding: 2px 2px;
	box-shadow: 0 2px 8px rgba(0,0,0,0.08);
	border-radius: 6px;
	border: none;
}

.date-filter {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 25px;
}

.date-filter input[type="date"] {
    padding: 8px;
    border-radius: 6px;
    border: 1px solid #ccc;
}

.date-filter button,
.btn-reset {
    padding: 8px 12px;
    background: var(--blue);
    color: #fff;
    border-radius: 6px;
    border: none;
    cursor: pointer;
    font-weight: bold;
    text-decoration: none;
}

.btn-reset {
    background: var(--gray-medium);
}

/*.calendar-grid { margin: 20px 0; }*/
/*.time-slots { display: flex; gap: 5px;}
.slot { padding: 5px 10px; border: 1px solid #ccc; cursor: pointer; background: #f0f0f0; }
.slot.occupied { background: #ccc; cursor: not-allowed; }
.slot:hover:not(.occupied) { background: #ff6b00; color: #fff; }
*/
.intervention {
  width: 100%;
}

.slot {
    padding: 8px 12px;
    margin: 5px;
    border-radius: 6px;
    border: 1px solid #ccc;
    background: #f8f9fa;
    cursor: pointer;
}

.slot:hover:not(.occupied) {
    background: #e7f1ff;
}

.slot.selected {
    background: #0d6efd;
    color: white;
    border-color: #0d6efd;
}

.slot.occupied {
    background: #eee;
    color: #999;
    cursor: not-allowed;
}

.choix_tec {
	padding: 8px;
	border-radius: var(--border-radius);
	border: 1px solid #ccc;
}