/*
 * DBS TimeManager — Client Portal Styles
 */

/* ── Layout ─────────────────────────────────────────────────────────────── */
.tm-client-wrap { max-width: 1200px; margin: 0 auto; }

/* ── Level tree ─────────────────────────────────────────────────────────── */
.tm-level-row {
    border-left: 3px solid transparent;
    transition: border-color .15s;
}
.tm-level-row.depth-1 { border-left-color: #0d6efd; }
.tm-level-row.depth-2 { border-left-color: #6f42c1; margin-left: 1.5rem; }
.tm-level-row.depth-3 { border-left-color: #fd7e14; margin-left: 3rem; }

.tm-level-header {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .5rem .75rem;
    cursor: pointer;
    user-select: none;
    background: #f8f9fa;
    border-radius: .25rem;
}
.tm-level-header:hover { background: #e9ecef; }

.tm-level-toggle { font-size: .8rem; transition: transform .2s; color: #6c757d; }
.tm-level-toggle.open { transform: rotate(90deg); }

.tm-level-title { font-weight: 700; flex: 1; font-size: 1.35rem; }
.tm-level-badges { display: flex; gap: .25rem; flex-wrap: wrap; }

.tm-level-detail {
    display: none;
    padding: 1rem 1.25rem;
    background: #fff;
    border: 1px solid #dee2e6;
    border-top: 0;
    border-radius: 0 0 .25rem .25rem;
    font-size: 2rem;
}
.tm-level-detail.open { display: block; }
/* Override theme's .small / small element inside detail panel */
.tm-level-detail small,
.tm-level-detail .small { font-size: .9rem !important; }

/* ── Edit form within level detail ─────────────────────────────────────── */
.tm-edit-form label { font-size: 1.5rem; font-weight: 600; color: #495057; }
.tm-edit-form .form-control,
.tm-edit-form .form-select { font-size: 1.5rem; }
.tm-edit-form .btn { font-size: 1.5rem; }

/* ── Save feedback ──────────────────────────────────────────────────────── */
.tm-save-msg {
    display: inline-block;
    font-size: 1rem;
    margin-left: .5rem;
    opacity: 0;
    transition: opacity .3s;
}
.tm-save-msg.show { opacity: 1; }
.tm-save-msg.ok   { color: #198754; }
.tm-save-msg.err  { color: #dc3545; }

/* ── Badge base reset — override any theme .badge color ─────────────────── */
/* All tm-* badge classes are self-contained; no Bootstrap color util needed */
.badge.tm-status-active,
.badge.tm-status-completed,
.badge.tm-status-onhold,
.badge.tm-status-canceled,
.badge.tm-priority-low,
.badge.tm-priority-normal,
.badge.tm-priority-high,
.badge.tm-priority-urgent,
.badge.tm-badge-date {
    display: inline-block;
    padding: .45em .85em;
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1;
    border-radius: .4rem;
    white-space: nowrap;
    vertical-align: middle;
}

/* ── Status badges ──────────────────────────────────────────────────────── */
.badge.tm-status-active    { background-color: #198754 !important; color: #fff !important; }
.badge.tm-status-completed { background-color: #0d6efd !important; color: #fff !important; }
.badge.tm-status-onhold    { background-color: #fd7e14 !important; color: #fff !important; }
.badge.tm-status-canceled  { background-color: #6c757d !important; color: #fff !important; }

/* ── Priority badges ────────────────────────────────────────────────────── */
.badge.tm-priority-low    { background-color: #20c997 !important; color: #fff !important; }
.badge.tm-priority-normal { background-color: #0dcaf0 !important; color: #000 !important; }
.badge.tm-priority-high   { background-color: #fd7e14 !important; color: #fff !important; }
.badge.tm-priority-urgent { background-color: #dc3545 !important; color: #fff !important; }

/* ── Date badges (replaces BS5-only text-bg-light) ──────────────────────── */
.badge.tm-badge-date { background-color: #f8f9fa !important; color: #212529 !important; border: 1px solid #dee2e6 !important; }

/* ── Drag-and-drop sort ─────────────────────────────────────────────────── */
.tm-drag-handle {
    cursor: grab;
    color: #adb5bd;
    font-size: 1rem;
    padding: .2rem .4rem;
    flex-shrink: 0;
    border-radius: .2rem;
    transition: color .15s, background .15s;
}
.tm-drag-handle:hover  { color: #495057; background: #dee2e6; }
.tm-drag-handle:active { cursor: grabbing; }

.tm-level-row.tm-dragging {
    opacity: .4;
    box-shadow: none !important;
}
.tm-level-row.tm-drag-over-before {
    border-top: 3px solid #0d6efd !important;
    margin-top: -1px;
}
.tm-level-row.tm-drag-over-after {
    border-bottom: 3px solid #0d6efd !important;
    margin-bottom: -1px;
}

/* ── Add task form ───────────────────────────────────────────────────────── */
.tm-add-task-card { max-width: 720px; }

/* ── Approved indicator ─────────────────────────────────────────────────── */
.tm-approved-badge { background: #198754 !important; color: #fff !important; font-size: 1.05rem; font-weight: 600; padding: .45rem .85rem; border-radius: .4rem; }
