/* Component-specific styles */

/* Mobile Data Cards */
.mobile-data-card {
    transition: all 0.2s ease;
}

.mobile-data-card.clickable-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.mobile-data-card .collapse.show + .d-flex .btn[data-bs-toggle="collapse"] i {
    transform: rotate(180deg);
}

.mobile-data-card .btn[data-bs-toggle="collapse"] i {
    transition: transform 0.2s ease;
}

/* Attendance specific styles */
.attendance-actions { 
    display: flex;
    flex-wrap: wrap;
    gap: .5rem; 
    justify-content: flex-start;
}

.attendance-actions .btn { 
    flex: 0 0 auto;
    min-width: 80px;
    padding: .5rem .75rem; 
    font-size: .9rem;
    font-weight: 500;
    border-radius: .5rem;
    border: 2px solid transparent;
    transition: all 0.2s ease;
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

.attendance-actions .btn:active {
    transform: translateY(0) !important;
}

/* Status button specific colors with hover effects */
.attendance-actions .btn-outline-success {
    background-color: #fff;
    border-color: #198754;
    color: #198754;
    border-width: 1px;
    font-weight: 400;
}

.attendance-actions .btn-outline-success:hover {
    background-color: #198754;
    border-color: #198754;
    color: #fff;
    transform: translateY(-1px);
}

.attendance-actions .btn-success {
    background-color: #198754;
    border-color: #198754;
    color: #fff;
}

.attendance-actions .btn-success:hover {
    background-color: #146c43;
    border-color: #146c43;
    transform: translateY(-1px);
}

.attendance-actions .btn-outline-danger {
    background-color: #fff;
    border-color: #dc3545;
    color: #dc3545;
    border-width: 1px;
    font-weight: 400;
}

.attendance-actions .btn-outline-danger:hover {
    background-color: #dc3545;
    border-color: #dc3545;
    color: #fff;
    transform: translateY(-1px);
}

.attendance-actions .btn-danger {
    background-color: #dc3545;
    border-color: #dc3545;
    color: #fff;
}

.attendance-actions .btn-danger:hover {
    background-color: #bb2d3b;
    border-color: #bb2d3b;
    transform: translateY(-1px);
}

.attendance-actions .btn-outline-warning {
    background-color: #fff;
    border-color: #fd7e14;
    color: #fd7e14;
    border-width: 1px;
    font-weight: 400;
}

.attendance-actions .btn-outline-warning:hover {
    background-color: #fd7e14;
    border-color: #fd7e14;
    color: #fff;
    transform: translateY(-1px);
}

.attendance-actions .btn-warning {
    background-color: #fd7e14;
    border-color: #fd7e14;
    color: #fff;
}

.attendance-actions .btn-warning:hover {
    background-color: #fd6500;
    border-color: #fd6500;
    transform: translateY(-1px);
}

.attendance-actions .btn-outline-info {
    background-color: #fff;
    border-color: #0dcaf0;
    color: #0dcaf0;
    border-width: 1px;
    font-weight: 400;
}

.attendance-actions .btn-outline-info:hover {
    background-color: #0dcaf0;
    border-color: #0dcaf0;
    color: #fff;
    transform: translateY(-1px);
}

.attendance-actions .btn-info {
    background-color: #0dcaf0;
    border-color: #0dcaf0;
    color: #fff;
}

.attendance-actions .btn-info:hover {
    background-color: #3dd5f3;
    border-color: #3dd5f3;
    transform: translateY(-1px);
}

.grade-actions { 
    display: flex;
    gap: .4rem;
    justify-content: flex-start;
    flex-wrap: wrap;
}

.grade-actions .btn { 
    flex: 0 0 auto;
    width: 45px;
    height: 45px;
    padding: 0;
    font-size: 1rem;
    font-weight: 600;
    border-radius: .5rem;
    border: 2px solid transparent;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

.grade-actions .btn:active {
    transform: scale(1) !important;
}

.grade-actions .btn-outline-success {
    background-color: #fff;
    border-color: #198754;
    color: #198754;
    border-width: 1px;
    font-weight: 400;
}

.grade-actions .btn-outline-success:hover {
    background-color: #198754;
    border-color: #198754;
    color: #fff;
    transform: scale(1.05);
}

.grade-actions .btn-success {
    background-color: #198754;
    border-color: #198754;
    color: #fff;
}

.grade-actions .btn-success:hover {
    background-color: #146c43;
    border-color: #146c43;
    transform: scale(1.05);
}

@media (max-width: 768px) {
    .attendance-actions { 
        display: grid; 
        grid-template-columns: 1fr 1fr; 
        gap: .5rem; 
    }
    
    .attendance-actions .btn { 
        width: 100%; 
        min-width: unset;
        padding: .5rem .5rem; 
        font-size: .85rem; 
    }
    
    .grade-actions { 
        display: grid; 
        grid-template-columns: repeat(5, 1fr); 
        gap: .3rem; 
    }
    
    .grade-actions .btn { 
        width: 100%;
        height: 40px;
        font-size: .9rem; 
    }
}