:root {
    /* Base gray-blue palette */
    --slate-900: #2F3E4D;
    --slate-700: #4A647D;
    --slate-500: #6B7C8F;
    --slate-200: #E4EAF0;
    --slate-100: #F2F5F8;
    --slate-type-bg: #EAF1F7;
    --slate-type-border: #D2DEE9;

    /* Accents */
    --accent-soft: #4DB6AC;
    --success-soft: #5FA777;
    --warning-soft: #F0B429;
    --danger-soft: #D64545;

    /* Semantic aliases (optional but nice) */
    --color-primary: var(--slate-900);
    --color-secondary: var(--slate-700);
    --color-bg: var(--slate-100);
    --color-card: #ffffff;
    --color-border: var(--slate-200);
    --color-text: #1F2A33;
    --color-muted: var(--slate-500);
}

/* The following replace They will replace bg-primary, bg-info, text-primary */
.bg-slate-dark { background-color: var(--slate-900); color: #fff; }
.bg-slate { background-color: var(--slate-700); color: #fff; }
.bg-slate-soft { background-color: var(--slate-100); }
.text-slate { color: var(--slate-700); }
.text-muted-slate { color: var(--slate-500); }

.btn-accent-soft {
    background-color: rgba(47, 158, 149, 0.15);
    color: #2F9E95;
    border: 1px solid rgba(47, 158, 149, 0.45);
    transition: all 0.2s ease;
}

.btn-accent-soft:hover {
    background-color: #2F9E95;
    color: #fff;
    border-color: #2F9E95;
    box-shadow: 0 4px 10px rgba(47, 158, 149, 0.25);
    transform: translateY(-1px);
}

.btn-orange-soft {
    background-color: rgba(249, 115, 22, 0.15);   /* soft orange background */
    color: #f97316;
    border: 1px solid rgba(249, 115, 22, 0.45);
    transition: all 0.2s ease;
}

.btn-orange-soft:hover {
    background-color: #f97316;
    color: #fff;
    border-color: #f97316;
    box-shadow: 0 4px 10px rgba(249, 115, 22, 0.25);
    transform: translateY(-1px);
}

.btn.btn-accent-soft:focus,
.btn.btn-accent-soft:focus-visible,
.btn.btn-accent-soft:active,
.btn.btn-accent-soft:active:focus,
.btn.btn-accent-soft:active:focus-visible {
    background-color: rgba(var(--accent-soft-rgb), 0.25);
    border-color: var(--accent-soft);
    color: var(--accent-soft);
    box-shadow: 0 0 0 3px rgba(47, 158, 149, 0.3) !important;
    opacity: 1 !important;
}

.btn.btn-accent-soft:active {
    transform: translateY(1px);
}

.btn-danger-soft {
    background-color: rgba(192, 57, 43, 0.12);
    color: #C0392B;
    border: 1px solid rgba(192, 57, 43, 0.45);
    transition: all 0.2s ease;
}

.btn-danger-soft:hover {
    background-color: #C0392B;
    color: #fff;
    border-color: #C0392B;
    box-shadow: 0 4px 10px rgba(192, 57, 43, 0.25);
    transform: translateY(-1px);
}

.btn-danger-soft:focus,
.btn-danger-soft:active {
    background-color: #992D22;
    border-color: #992D22;
    box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.3);
}

.btn-warning-soft {
    background-color: rgba(240, 180, 41, 0.15);
    color: #F0B429;
    border: 1px solid rgba(240, 180, 41, 0.45);
    transition: all 0.2s ease;
}

.btn-warning-soft:hover {
    background-color: #F0B429;
    color: #fff;
    border-color: #F0B429;
    box-shadow: 0 4px 10px rgba(240, 180, 41, 0.25);
    transform: translateY(-1px);
}

.btn-warning-soft:focus,
.btn-warning-soft:active {
    background-color: #C48B18;
    border-color: #C48B18;
    box-shadow: 0 0 0 3px rgba(240, 180, 41, 0.3);
}

.btn-slate-soft {
    background-color: rgba(58, 79, 102, 0.12);
    color: #3A4F66;
    border: 1px solid rgba(58, 79, 102, 0.45);
    transition: all 0.2s ease;
}

.btn-slate-soft:hover {
    background-color: #3A4F66;
    color: #fff;
    border-color: #3A4F66;
    box-shadow: 0 4px 10px rgba(58, 79, 102, 0.25);
    transform: translateY(-1px);
}

.btn-slate-soft:focus,
.btn-slate-soft:active {
    background-color: #2C3E50;
    border-color: #2C3E50;
    box-shadow: 0 0 0 3px rgba(58, 79, 102, 0.3);
}

.select-success-soft {
    background-color: var(--success-soft);
    color: #fff;
    border: 1px solid var(--success-soft);
    --bs-form-select-bg-img: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}

/* focus state */
.select-success-soft:focus {
    box-shadow: 0 0 0 0.2rem rgba(95, 167, 119, 0.25);
    border-color: var(--success-soft);
}

.select-success-soft option {
    color: #000;
}

.form-select {
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

:focus-visible {
    outline: 2px solid var(--accent-soft);
    outline-offset: 2px;
}

.section-header {
    background: linear-gradient(
        180deg,
        var(--slate-700),
        var(--slate-900)
    );
    color: #fff;
    font-weight: 600;
    padding: 10px 14px;
    border-radius: 10px 10px 0 0;
    letter-spacing: 0.2px;

}

.card-header.section-header {
    min-height: 51px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.section-card {
    border: 1px solid var(--slate-200);
    border-radius: 10px;
    background: #fff;
}

/* COLUMN LAYOUT */
/*.dodac-layout {
    display: grid;
    grid-template-columns: 4.5fr 8.5fr;
    gap: 1rem;
}*/

.dodac-layout {
    display: grid;
    grid-template-columns: 4fr 9fr; /* slightly wider left */
    gap: 1rem;
    align-items: start;   /* prevents vertical stretching if needed */
}

.left-col,
.right-col {
    min-width: 0;
}

body {
    background-color: var(--color-bg);
    color: var(--color-text);
}

.card {
    background: var(--color-card);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    overflow: hidden;
}

.card > .card-header:first-child {
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}

.card-header {
    background: var(--slate-100);
    color: var(--slate-900);
    font-weight: 600;
    border-bottom: 1px solid var(--slate-200);
}

.card-header.bg-success-soft {
    background-color: var(--success-soft) !important;
    color: #fff;
}

.card-header.bg-danger-soft {
    background-color: var(--danger-soft) !important;
    color: #fff;
}

.list-group-item {
    font-size: 0.95rem;
}

.accordion-button {
    background-color: var(--slate-100);
    color: var(--slate-900);
    font-weight: 600;
    border-bottom: 1px solid var(--slate-200);
}

.accordion-button.collapsed {
    background-color: var(--slate-100);
    color: var(--slate-700);
}

.accordion-button:not(.collapsed) {
    background-color: #fff;
    color: var(--slate-900);
    box-shadow: inset 0 -1px 0 var(--slate-200);
}

.accordion-button:focus {
    box-shadow: none;
}

/* Make sure dropdowns are visible above other content */
.dropdown-menu {
    z-index: 1050; /* Bootstrap default */
}

.dropdown-menu-wide {
    min-width: 280px;
}

.dropdown-menu-wide .dropdown-item {
    white-space: nowrap;
}

/* Optional: style caret */
.nav-link .caret {
    margin-left: 0.4rem;
    font-size: 0.65em;
    color: var(--accent-soft);
    pointer-events: none;
}

/* Active link underline for navbar links, including dropdown toggles */
.navbar-dark .navbar-nav .nav-link.active,
.navbar-dark .navbar-nav .nav-link.dropdown-toggle.active {
    position: relative;
    display: inline-block; /* ensures ::after spans width */
    color: var(--accent-soft);
    box-shadow: inset 0 -0.1rem 0 0 var(--accent-soft); /* Fallback underline */
}

/* Remove ::after rules if using box-shadow */
.navbar-dark .navbar-nav .nav-link.active::after,
.navbar-dark .navbar-nav .nav-link.dropdown-toggle.active::after {
    display: none;
}

/* Ensure dropdown toggle has no extra spacing */
.navbar-dark .navbar-nav > li > .nav-link.dropdown-toggle {
    padding-bottom: 0.25rem;
    margin-bottom: 0;
}

.dropdown-item.active,
.dropdown-item:active {
    background-color: rgba(77, 182, 172, 0.15);
    color: var(--accent-soft);
    font-weight: 500;
}

.navbar-dark .dropdown-toggle::after {
    display: none;  /* removes Bootstrap's white arrow */
}

.badge-success {
    background-color: var(--success-soft);
}

.badge-warning {
    background-color: var(--warning-soft);
    color: #1F2A33;
}

.badge-danger {
    background-color: var(--danger-soft);
}

.badge-info {
    background-color: var(--accent-soft);
    color: #fff;
}

/* ===========================
   SOFT BADGES (like btn-*-soft)
   =========================== */

.badge-info-soft {
    background-color: rgba(77, 182, 172, 0.15);
    color: var(--accent-soft);
    border: 1px solid rgba(77, 182, 172, 0.35);
}

.badge-warning-soft {
    background-color: rgba(240, 180, 41, 0.15);
    color: var(--warning-soft);
    border: 1px solid rgba(240, 180, 41, 0.35);
}

.badge-danger-soft {
    background-color: rgba(214, 69, 69, 0.15);
    color: var(--danger-soft);
    border: 1px solid rgba(214, 69, 69, 0.35);
}

.badge-slate-soft {
    background-color: rgba(74, 100, 125, 0.12);
    color: var(--slate-700);
    border: 1px solid rgba(74, 100, 125, 0.35);
}

* {
    font-family: "Inter", "Segoe UI", system-ui, sans-serif;
}

.card, .btn, .badge {
    box-shadow: 0 2px 6px rgba(0,0,0,0.04);
}

h1, h2, h3, h4 {
    font-weight: 600;
    letter-spacing: 0.2px;
}

.badge-slate {
    background-color: var(--slate-700);
    color: #fff;
}

.badge-confidential {
    background-color: var(--danger-soft);
    color: #fff;
}

.badge-followup {
    background-color: var(--success-soft);
    color: #fff;
}

.badge-files {
    background-color: var(--accent-soft);
    color: #fff;
}

.badge-admin {
    background-color: var(--slate-500);
    color: #fff;
}

.badge {
    font-weight: 500;
    letter-spacing: 0.02em;
    padding: 0.35em 0.6em;
    border-radius: 6px;
}

.bg-slate-100 {
    background-color: var(--slate-100);
}

.bg-danger-soft {
    background-color: var(--danger-soft) !important;
    color: #fff;
}

.btn-accent {
    background-color: var(--accent-soft);
    color: #fff;
}

.btn-accent:hover {
    filter: brightness(0.95);
}

.btn-slate {
    border: 1px solid var(--slate-200);
    color: var(--slate-700);
}
.btn-slate:hover {
    background-color: var(--slate-100);
}

.eleve-photo {
    width: 100px !important;
    height: 150px !important;
    object-fit: contain;
    border: 1px solid var(--slate-200);
}

.card-text, .list-group-item p, .list-group-item small {
    font-size: 0.95rem;
}

.btn-danger-alpha {
    background-color: rgba(214, 69, 69, 0.12);
    color: var(--danger-soft);
    border: 1px solid rgba(214, 69, 69, 0.3);
}

.btn-danger-alpha:hover {
    background-color: rgba(214, 69, 69, 0.2);
}

.modal-header.section-header {
    border-top-left-radius: 0.3rem;
    border-top-right-radius: 0.3rem;
    margin: -1px -1px 0 -1px; /* extend slightly to cover edges */
}

.modal-danger .modal-header {
    background-color: rgba(214, 69, 69, 0.08);
}


.info-tooltip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    margin-left: 6px;

    border-radius: 50%;
    border: 1px solid var(--danger-soft);
    color: var(--danger-soft);
    font-size: 11px;
    font-weight: 600;

    cursor: help;
    position: relative;
    line-height: 1;
}

.info-tooltip:hover {
    background-color: var(--accent-soft);
    color: #fff;
}

/* Tooltip bubble */
.info-tooltip-text {
    visibility: hidden;
    opacity: 0;
    width: 320px;
    background-color: var(--slate-900);
    color: #fff;
    text-align: left;
    padding: 8px 10px;
    border-radius: 8px;
    position: absolute;
    z-index: 1000;
    bottom: 140%;
    left: 50%;
    transform: translateX(-50%);
    transition: opacity 0.15s ease;
    font-size: 0.8rem;
    line-height: 1.4;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);

    text-transform: none;   /* 👈 IMPORTANT */
}

/* Tooltip arrow */
.info-tooltip-text::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-width: 6px;
    border-style: solid;
    border-color: var(--slate-900) transparent transparent transparent;
}

.info-tooltip:hover .info-tooltip-text {
    visibility: visible;
    opacity: 1;
}

.info-tooltip .badge {
    width: auto;          /* allow normal badge size */
    height: auto;
    display: inline-block;
    padding: 0.25em 0.4em; /* default Bootstrap badge padding */
    font-size: 0.75rem;    /* optional: adjust size */
    background: #ffc107;   /* warning bg */
    color: #212529;        /* dark text */
}

.info-tooltip::before {
    content: none; /* remove any "?" circle behind */
}

/* Tooltip date at top right with thin underline */
.info-tooltip-date {
    text-align: right;
    font-size: 0.7rem;
    font-weight: 500;
    border-bottom: 1px solid rgba(255,255,255,0.3); /* thin line */
    margin-bottom: 4px;
    padding-bottom: 2px;
}

/* Tooltip comment below date */
.info-tooltip-comment {
    font-size: 0.8rem;
    font-weight: 0.8rem;
    line-height: 1.4;
}

.badge-clickable {
    cursor: pointer;      /* show pointer on hover */
    transition: transform 0.15s ease;
}

.badge-clickable:hover {
    transform: scale(1.05); /* optional subtle scale effect */
}

.table {
    table-layout: fixed;
    width: 100%;
}

.rights-badges {
    min-width: 0;
}

.badge-split {
    display: inline-flex;
    line-height: 1;
    font-size: 0.8rem; /* adjust as needed */
}

.badge-split .badge-left {
    background-color: var(--accent-soft);
    border-top-left-radius: 0.25rem;
    border-bottom-left-radius: 0.25rem;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.badge-split .badge-right {
    background-color: var(--danger-soft);
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: 0.25rem;
    border-bottom-right-radius: 0.25rem;
}

.badge-unique {
    border-radius: 0.25rem;
    background-color: var(--accent-soft);
    color: white;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    height: 1.5em;   /* same as left/right badges */
    font-size: 0.65rem !important; /* match Bootstrap .badge font-size */
    padding: 0.25em 0.5em; /* match px-2 py-1 */
    line-height: 1;  /* ensures vertical alignment */
}

.category-title-left {
    text-align: left;
    color: var(--accent-soft);
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
}

/* Tabs: default (unselected) */
.nav-tabs .nav-link {
    color: #000;
    font-weight: 500;
}

/* Tabs: hover (optional) */
.nav-tabs .nav-link:hover {
    color: var(--accent-soft);
}

/* Tabs: active */
.nav-tabs .nav-link.active {
    color: var(--accent-soft);
    background-color: transparent;
    border-color: #dee2e6 #dee2e6 #fff;
    border-bottom: 2px solid var(--accent-soft);
}

.card.hover-shadow:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0,0,0,0.15);
    transition: all 0.2s ease;
}

/* Turn text and icon green on hover */
.card.hover-shadow:hover .fw-semibold,
.card.hover-shadow:hover small,
.card.hover-shadow:hover .eleve-icon {
    color: var(--accent-soft);
    transition: color 0.2s ease;
}

/* Default bar color (slate) */
.card.position-relative .right-bar {
    top: 0;
    bottom: 0;
    right: 0;
    width: 4px;
    background-color: var(--slate-700); /* default slate */
    transition: background-color 0.2s;
}

/* Only when THIS card is hovered, change its bar */
.card.position-relative:hover .right-bar {
    background-color: var(--accent-soft);
}

/* ================================
   Base type-header style
   ================================ */
.list-group-item.type-header {
    position: relative;
    display: flex;
    align-items: center;
    padding-left: 18px;       /* space for left bar */
    padding-right: 10px;
    padding-top: 10px;
    padding-bottom: 10px;

    background-color: var(--slate-100); /* light background */
    /*color: var(--slate-900);            /* dark text */

    border: none;           /* remove old borders */
    border-radius: 0;       /* remove rounding */
    margin-bottom: 4px;

    cursor: default;
    overflow: visible;
}

/* ================================
   Left highlight bar
   ================================ */
.type-bar {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 6px;
    border-radius: 0 6px 0 0; /* rounded top-right & bottom-right */
}

.with-bar {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 6px;
    border-top-left-radius: 10px;
}

/* ================================
   Type colors for left bar AND text
   ================================ */
/* ================================
   Type colors for left bar, text & bottom border
   ================================ */
/* ================================
   Type colors for left bar, text & bottom border
   Matching your TYPE_CLASSES passed to Twig
   ================================ */

/* Admin */
.list-group-item.type-header.badge-admin {
    border-bottom: 1px solid var(--slate-500);
    color: var(--slate-500);
}
.type-bar.badge-admin {
    background-color: var(--slate-500);
}

/* Confidential */
.list-group-item.type-header.badge-confidential {
    border-bottom: 1px solid var(--danger-soft);
    color: var(--danger-soft);
}
.type-bar.badge-confidential {
    background-color: var(--danger-soft);
}

/* Follow-up / Prof */
.list-group-item.type-header.badge-followup {
    border-bottom: 1px solid var(--success-soft);
    color: var(--success-soft);
}
.type-bar.badge-followup {
    background-color: var(--success-soft);
}

/* Warning / Educ */
.list-group-item.type-header.badge-warning {
    border-bottom: 1px solid var(--warning-soft);
    color: var(--warning-soft);
}
.type-bar.badge-warning {
    background-color: var(--warning-soft);
}

/* Danger / Abs */
.list-group-item.type-header.badge-danger {
    border-bottom: 1px solid var(--danger-soft);
    color: var(--danger-soft);
}
.type-bar.badge-danger {
    background-color: var(--danger-soft);
}

/* Files */
.list-group-item.type-header.badge-files {
    border-bottom: 1px solid var(--accent-soft);
    color: var(--accent-soft);
}
.type-bar.badge-files {
    background-color: var(--accent-soft);
}

/* Email / Info */
.list-group-item.type-header.badge-info {
    border-bottom: 1px solid var(--accent-soft);
    color: var(--accent-soft);
}
.type-bar.badge-info {
    background-color: var(--accent-soft);
}

.classe-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    text-align: right;
}

/* On smaller screens, stack columns vertically */
@media (max-width: 768px) {
    .classe-grid {
        grid-template-columns: 1fr; /* 1 column instead of 3 */
        text-align: left;           /* optional: left-align for mobile */
    }
}

@media (max-width: 768px) {
    .classe-actions {
        flex-direction: column; /* stack buttons vertically */
        align-items: stretch;   /* make buttons full-width if desired */
    }
}

.list-item-layout {
    display: grid;
    grid-template-columns: 200px 1fr 170px;
    gap: 24px;
    align-items: start;
}

.list-item-middle {
    min-width: 0; /* prevents content from stretching grid */
}

.list-item-right {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

.middle-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 200px;
    align-items: center;
    gap: 12px;
    margin-bottom: 6px;
}

.course-badge {
    white-space: normal;
    justify-self: start;
}

.teacher-badge {
    justify-self: end;
}

.subd-grid {
    display: grid;
    grid-template-columns: 1fr 1fr auto; /* courses / teachers / icons */
    grid-auto-rows: minmax(1rem, auto);   /* each slot same row height */
    gap: 0.25rem 0.5rem;                  /* vertical / horizontal spacing */
}
.course { grid-column: 1; }
.teacher { grid-column: 2; }
.exist { grid-column: 3; text-align: center; }

.comp-badge {
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: inline-block;
}

/* assets/styles/app.css or your main stylesheet */
.drag-handle {
    cursor: grab;          /* default “grab” icon */
    user-select: none;     /* prevent text selection while dragging */
}

.drag-handle:active {
    cursor: grabbing;      /* when dragging */
}